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System und VerfaJiren zur autaxnatisierfcen Erzeugung von. . 
druckbaren Dateien aus Datea 

Beschreibung: - 

s .- • . 

Die Erf induhg betrif ft ein System zur automatisierten 
* Erzeugung von druckbaren Dateien aus Dateli; einer Datenbank, 
das ein Druckeystetn bestehend aus wenigstens einer 
DrucJcverarbeitungskomponente umfasst, wobei die 
10 Druckverarbeitungskomponente Mittel zura Ausdrucken und/oder 
Weiterverarbeiten der Dateien aufweist. 

Die Erf indung betrif ft ferner ein Verfahren zur 
automatisierten Erzeugung von druckbaren Dateien aus Daten 
( einer Datenbank, bei dem die Dateien von einem Drucksystem 
as bestehend aus wenigstena einer Druckverarbeitungskontponente 
.und einem Druckauf tragerzeugungsmittel erzeugt, ausgedruckt 
und/oder weiterverarbeitet werden. 

Die Erzeugung yon druckbaren Dateien gewinnt zunehmend an 
Bedeutung, da aiif den verachiedensten Anwendungsgebieten ' 
20 immer grfifiere Mengen von Druckobjekten elelctronisch erzeugt, 
weiterverarbeitet und ausgedruckt werden. Insbesondere 
besteht der Bedarf , individual is ierte Postsendungen auf 
elektronischem" Wege zu erzeugen und diese anschlieSehd 
auszudrucken' und weiter zu verarbeiten. . *■ 

25 Beispielsweise bieten Postunternebmen laber den reinen Brief - 
und Paketversand ' hinaue zablreiche Dienstleistungen im Brief - 
und Mailingbereich an. Dabei wird innerhalb eines derartigen 
Systems der gesamte Erstellungsprozess fur gedruckte und zu 
versendende Dokumente Uiiterstutzt . Mit der wachsendeH ■ 
30 Bedeutung der Elektronischen Post gilt dies auch im Bereich 
der E-Mail Kommunikation und der- Internet -basiert en liogistik- 

Dabei dienen Komponenten eines fiir derartige Abl&ufe 
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konzipierten Systems verechiedenen Zwecken. Z\im Einen <Jienen 
eie als Einlief erungsschnittstelle urid Produktionssystem far 
letztendlich papierxie, gedruckte Brief sendungen, die per Post 
an den Empf anger zugestellt warden. Zum Anderen bieten' 
s. Systeinkomponenten mit Schnittstellen eine direkte • 

fteergabemdglichkeit f ttr Naxshrichten auf elektronischem Wege . ' 
Versand und Auslieferung kSnhen so per E-Mail land. Web- 
:, Protokollen erfolgen. 

10 Pur den Anwender sind zur Nutzung. dieser Angebpte eVlnige 
pro'duktipnstechnische Harden zu \iberwinden . Dies geht yorrt 
Entwurf eines Mailings ilber die Beschaffung von 
Zielgruppenadressen bis zum eigentlictien Seriendruck 
, inklusive Qualitatskontrolle. Selbst bei Zuhilf enahme 

.15 spezialisiarter Dienstl£ister wie fcettershops und 

Druckzeritren" erweist sich die Mailingerstellurig immer noeh 
ale komplexer Prozess , Mehrf ache Medienbrtiche und heterogene 
Schnittstellen, beziehungsweise Denkweisen unterschiedlich'er 
involvierter Zwischenstellen, machen den Prozess fur kleihe 

20 sendungsanzahlen teuer und aufwendig.. Fiir grofie Mailings ist 
er zeitintenpiv und technisch komplex. 

Zum Drucken und toreiterverarbeiten von Druckauftragen 
innerhalb. eines Drucksystems warden typischerweise 

25 verachiedene Druckverarbeitungskornponenten wie Drucker, 

' ; • Sortier- und Kuvertieranlagen oder sonstige 

rverarbeitungsgerate verwendet . Dadurch ergeben sich 
vielf aitige M6glichkeiten ftir Hardwarekombinatipnen und 
Arbeitsablaufe, die jeweils eine spezielie Druckaufbereitung 

so erfordem.. 

Druckaufbereitungsverf a'hren ftir verschiedenste Anf otfderungen 

sind aus dem Stand der Technik bekannt Die Deutsche 
' .**'.■' 
Patentschrif t DE 199 21 120 C2 beschreibt beispielsweise ein 

3S /Verfahren und ein system zum signaturweisen Ausschiefien von 
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Drxickdaten- innerhalt) eifres POD (Print On Demand) -Systems. 
Dabei. ist das Druckefi und Falten yon Drucjtbogen betroffen, 
bei denendie Druckbilder auf einanderf ol^ender Seiten 
passergenau . zue'iriander liegen. , . 

* ' • . . 

Aus der' Deutschen Patentschrif t DE 100. 17 785 C2 1st ferner 
ein verf ahren "unci ein System zur' Verarbeitung- eines, , 
Datenstroms bekannt/bei dem. dear Datenstrom' zur Ausgabe auf 
^xn^m Druckger&t aufbereitet wird. Dabei wird ein ' 
Druckdatenstrom, der' in' einem , ersten Druckdatenf ormat 
vorliegt, . in ein horraiertea Datenformat umgesetzt, und der 
derkrtig umgeBetzte Druckdatenstrom aiihand vorgeg'ebener ; 
indlziean^gskriterien indiziert. Der Indizierte 
Druckdatenstrom. wird- dann mittels , Sortierparameter in einer 
Bortierreihenfolge sortiert und der. sorfcierte Druckdatenstrbni 
zur weiteren Verarbeitung, insbesondere zum Ausdruck, 
ausgegeben .■ 

In der Praxis stellt sich oftmals das Pr9blem; dass 
^ruckauf trSge an verschiedene'Drucksysteme ubergeben wetdeii, 
wobei die Drucksysteme jeweils eina unterschiedliche . 
Datenaufbereitung erfordern. Dies ist insbesondere der Fall., 
wenn beispielsweise ein Postunternehraen ' Dateri fur 
Druckauftrage von Benutzem eines dafftr. konzipierten < 
Servicesystems entgegennimmt, diese in einer zentralen 
Datenbank speichert und die Ausfuhrung der .Druckauftrage 
eigenan Systemkomponenten odepr Druckdienstleistern tibergibt. 
Jeder bruckdienstieister verfdgt typischerweise tiber ein fur 
ihn , spezif isches Drucksystem mit ver^ohiedenen Soft- und 
Hardwarekomppnenten. Urn die Benutzerauf frage nach Annahme der 
Daten durch das Postunternebmen einheitlifch auf zubereiten und 
als fertige Druckauftrage an das jeweilige Drucksystem der. ■ 
Dienstleister zu flbermitteln/ ist beirri Postunternehmen die 
Kenntnis aller Spezif ikationen der beauftragten 
Druckdierist leister erforderlich. Dies erfordert wiederum 
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einen erheblichen Auf wand an Hard- und Software auf Seiten 
des Postunternehmens . . . • 

Die Deutsche Of f enlegungeechrif t DE 198 17 878 Al of fenbart 
s dazu belspielswelse ein, Verfahren und elne Vorrichtung zur 
Herstellung, UtnhQ 1 lung , und Kuvertierung von Druckaendungen . 
' Dabel werden Druckdaten beiro Auftraggeber eines Druckauftrags 
hergestellt und uber ein Netz an eine Druckeinrichtung 
ubertragen, in dear die ubertragenen Druckdaten ausgedruckt 
10 werden. Der Auftraggeber erstellt den Druckauftrag auf seinem 
• Personal Computer, dermic einem oder mehreren 
Zentralreehnern verbunden' ist . Die Zentralrechner sihd 'mit 
Servern verbunden, die sich beispielswelse in verschiedenen 
Stadten oder Landem befinden kdnnen. Der Auftraggeber wShlt 
oinen Server mit freier Druckkapazit.at und ubermittelt diesem 
den Druckauftrag, Dieaer Druckauftrag lduf t . be,im ausgewahlten 
Server vollaufcomatiech ab, wobei der Server vorzugeweiae 
einen weiteren Personal Computer und eine Druckeinrichtung'. ■ 
auf weist . Der .Druckauftrag wird auf dem Perspnal Computer 
gespeichert und die Druckeinrichtung nult verschiedenen 
Komponenten w ie Papierrollen, Beleimungemaschinen, DrucJo, 
schnelde-, Umhullungs- und Palteinheiten von diesem 



15 



20 



angpesteuerb . 



25 




30 



3& 



Die Deutsche Off enlegungeechrif t DB 101 2.2 488 Al be.chreib,: 

„ f ! D ° kU " ,ente 10 ^ ■*-*«M B U Betel*.*™* 
dee globele Dota^eteneigeneehaf ten eaihSlt . . Debei 
Obemdttelt ein Kunde de„ Drucksyetem direjet in Pepierfo™ 

fur zu druckende Objekte. 9 
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Die Deutsche Of f enlegungsschrif t DB 101 22 880 Al offenbart 
ein Verf ahren zur automatischen Erzeugung von 
. Druckanweisungen. An einem Computer werden dazu von einem 
Bediener Anweisungen eingegeben, dam it der Computer eine 
s Vielzahl voA erhaltenen Dokumenten in einen elektronischen 
Ordnerstellt und die - Dokumente in dem Ordner in der fur das 
gedruckte. Endprodukt gewunschte Reihenfolge anordnet. Die 
Obermittlung des Auf trags eines Kunden an das. Drucksystem 
erfolgt hierbei ebeitfalls direkt in Pipierf orm, auf -einem 
io Datentr&ger oder Ober das Internet einen Auf trag fur zu 
druckende Objekte. 

Der Erfindung liegt die Aufgabe zugrunde, ein System zu 
. schaffen,- das es einem Drucksystem ermoglicht, ' Daten aus 
.is \ einer Datenbank aufierhaib des Bereiches des Drucksyst.ems zu 
erhalten und aus diesen Daten in Abhangigkeit von den 
spezif ischen Anf orderungen des Druckeystems automatisiert 
druckbare- Dateien zu generieren. 

-20 Aufgabe der Erfindung iet es ferner, ein Verf ahren zur 

automatisierten Erzeugung von Druckauf tr&gen aus Daten einer 
Datenbank durch ein Drucksystem bereitzuBtellen, bei dem sich 
die Datenbank aufierhalb des Bereiches des Drucksystems 
befindet., 

25 ; 

. V ' Erfindungsgemafi wird diese Aufgabe durch ein System zur . 
' automatisierten Erzeugung von druckbaren Dateien aus Daten 

einer Datenbank gelost, das ein Drucksystem bestehend aus 

wenigstens einer Druckverarbeitungskomponente umfasst, wobei 
30 die Druckverarbeitungskomponente Mittel zum Ausdrucken 

und/pder Weiterverarbeiten der Dateien auf waist, und das 

System folgende Merkmale umfasst : 

das Drucksystem weist wenigstens ein 
35 Druckauf tragerzeugungsmittel auf, 
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das Druckauftragerzeugungsmittel ist fiber- aine 
erste Schnittstelle .mit einem Server verbindbar, 

der Server* 1st- -fiber eine zweite Schnittstelle. mit 
einer Datenbank verbindbar. 

dae Druckauftragerzeugungsmittel weist Mittel zum 
Anf ordern urid Empf angen von Da ten aus der 
Datenbank auf , und ; 

das Daruckauftragerzeugungsmittel weist ; Mittel zur 
Auf bereitung der Datexi der Datenbank f ftr die 
Anf orderungen der Druckverarbeitungskpn^onente und 
Mittel zur Erzeugung von druckbaren. Dateien auf . 




Die Aufgabe wird ferner durch e in Verf ahren zur 
automatisierten Erzeugung von .druckbaren Dateien aus Daten. 
ao einer Datenbank gelost, bei dem die Dateien' von einem 
Drucksystem bestehend aus wenigstene einer , 
Dxuckverarbeitungekomponente und einem 

Drruckauftragerzeugungsmittel erzeugt, ausgedruckt und/oder 
weiterverarbeitet werden, und das Verf ahren folgende Schritte 
25« "umfasst;: 

- Das Druckauftragerzeugungsmittel erzeugt eine 

erste Nachricht, die einen Aufruf einer bestitnmten 
Methbde mit Parametem an einem Server belnhaltet, 



30 



Das Druckauftragerzeugungsmittel stellfc tiber eine 
erste* Schnittstelle eine Verbindung zu dem Server 
her, 



35 



das Druckauftragerzeugungsmittel Obermittelt dem 
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Server die erste Nachricht uber die erste 
Schnittstelle, 

\ • : . . 

der Server verarbaitet die erste KTachricht, indent' 
er die bestiromte Methode mit den zugehorigen ' 
Paranietern aiif ruf t , • • 



- der server stellt fiber eine zweite Schriittsteile 

... . .... • • . i , . • 

e'ine Verbinduiig zu- der Datenbank her , 

der Server ruft ilber die zweite Schnittstelle 
Da ten aus der Datenbank ab, ' 

der Server gibt . das Brgebnis des Aufrufs der 
is. bestitnmten Methode in Form einer zweiten Nachricht 

an das Druckauf tragerzeiagungsmlttel zuruck, und 

[ - das Druckauftragerzeugungsmittel erzeugt aus dem 
Ergebnis dee Aufirufs der * bestimmten Methode 
20 ' wenigstens eine "druekbare Datei. 



Bei dem Drucksystem handelt es eich beispielsweise um ein 
System bei.einem Druckdienstleister, da© Dnieker, Sortier- 
;2B urid Kuvertieranlagen und/oder weitere VerarbeitungsgerSte 
: uraf asst . Innerhalb eines solcne'h Drucksystems 1st. 
erfindungegem&JS ein Druckauf tragerzeugunigsmittel installiert , :■ 
das mit'einem Server verbindbar ist . Der Server wiederum 1st. 
. mit einer Datenbank verbindbar, welche Daten fur zu 
30 ^rstellende. Dfucke euathftlt. ,Die Datenbank* befindet eich . 

auSerhalb • des Druriksystems lind umfasst; typischerweise grofia * 
< Datenmehgen . Diese Daten stammen beispielsweiBe von Benutzern 
eines Servicesyetems eines Postuntemehmens , die ' 
Druckauftr&ge ffir Mailings in Auftrag gegeben haben.. ' 
as ' ; .■ 
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Bel dem *erf indungsgemafien Druckauf t^agerzeugungsniittel . 
Jiandelt.es siph typischerweise urn .ein' Programm, das 
vorzugsweise auf Computern des Drucksystems installiert 1st. 
Der Begriff uComputer 11 ist dabei in keirier Weise 
5 ' einschr&nkend zu verstehen. Es kann sich hierbei um .eine ' 
beliebige, \zur Durchftihrung von Berechiiungen .geeignete 
4 Eintieit bandeln, beispielaweise eine Workstation,, einen . 

Personal comput er , ' einen Mikrocumputer oder eine zur , • 
. burchf -Qhrung von Berechnungen und/p.der Vergleichen geeignete 
io Schaltung. 

• . . . . i - \ ' ' * ' ' i 

In einem besdnders bevor^u'gten :Ausfuhrungsbeisplel der 
Brfindung ist das Druckauf tragerzeugungsmitt el in Form einer 
• ersten Schnittstelle Ober eine SOAP-Schnittstelle mit einem 
'■'i5' : SOAP- Server verbindbar. Die Abkurziing SOAP steht fiir Simple 

Object Access Protocol. SQAP ist ein Kommunikationsprdtokoll' 
feum Zugang zu eirizelnen Programmmodulen im Internet, SOAP .ist 
ein schlankes Protokoll, mit dem proprietor a Module verpackt 
und mit allgemein verstandlichen Schnittstellen versehen 
20 werden kfinnen.' SOAP legt test, wie ein Funktionsaufruf mit 
XML-Daten aber Rechnerplattf ormen {Remote Procedure Call) 
hinweg erfolgt, Vosteilhaf t ist eine Verbindung zu dem Server 
•uber das Internet; es sind jedoch aiich andere yerbindungen " 
. mSglich. Dabei kann es sich urn temporSre pder feste 
■ 25 yerbindungen handeln. • ■ ' 

Der Server ist erf indungsgem&fi uber. eine zweite Schnittstelle 
mit wenigstens einer . Datenbank verbindbar. In einem besonders 
bevorzugten Auef uhrungsbeispiel der Brfindung wird zur . 
. ?o Verbindung zwischen Server und Datenbank ein PL/SQL-Layer 
•• eingesetzt. Die Abkurzung PL/SQL' stent fAr Procedural 
Language/Structured Query Language. Dabei handelt e& aichum 
■ _ eine proprietare Programmiersprache beispielsvreise fiir 

Oracle, die dem nicht-prozedualen SQL prozeduale Kohstrukte' ' 
3S und St'euerungBm6glichkelten hinzuf ugt . fiber den Server we r den 
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dem Druckauf tragerzeugungsmittel so Daten.aug der Datenbank 
ubeotmittelt, die beispielsweise Vorlagen, variable Daten, 
Personalisierungsanwaisungen und weitere Inf optnationen tiber t . 
zu erstellende Druckauf tr&ge enthaltenl 

5 

Das Druckauf tragerzeugungsmittel erstellt aus. den erhaltenen 
Daten Druckauf t rage , und geneyiert daraue automata siert 
druckbare Dateien. Das Druckauf trager zeugungsmi'tt el . 
beschreibt dabei, wie die Dateien filr. eine bestinimte 
■ io Papier/Hardware-K;ombination auf zub&reiteri sind. Dies umfasst 
beispielsweise Informationsseiten* ftir das Personal, 
' • ■ steuerzeicften 'filr eine Kuvertieranlage, Sdfcmittmarkien, 

•Papierformate, das Erzeugeh von RIP-Xickets filr Drucker, SDL- 
Steuerzeichen, Konvert ieningeanwei sungen und Anweisungen, wie 
15 die Daten zu einem Drucker " transport iert werden. 

Die Daten in der Datenbank stellen Au£trage von Benutzern 
uber das Drucken von Pdst'aendungen dar. Auftrage von 
Benutzern werden im Folgenden als UserJobs- bezeichnet, 
20 wahrend daraus resultierende Druckauf tr&ge als Printtfoba 

bezeichnet werden. Da die von Benutzern erzeugten UsefJobs 
sehr unterschiedlicher GrqSe seixi kopnen, und. die PrintJobs 
f-Qr eine optimeile Produktion zweckm&Sigerweise weder zu klein 
noch zu grofi sein sollten, hat es sich als vorteilhafit 
25 ' erwiesen, grofce Auf tr&ge zu teilen, und/oder mehrere kleine 
.Auftrage zu grdfceren zusairanen.zu fassen. Besonders bevorzugt 
ist dazu die Implementation eitxes Mechanismus, der grotee ' 
Auftr&ge automatiscb teilt. 

30 Weitere Vorztige, Besonderheiten' und zweckmaSige 

• ■ • *. ♦ ■ 

'[ • Weiterbildungen der Erfindung ergeben sich aue den 

Unteranspruchen und der nachfolgenden Darstellung bevorzugter 

Aus ftihrungsbei spiel £ anhand der' Abbildungen. 

33 Von den Abbildungen zeigt 
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• Fig. 1 . , den schematischen Aufbau eines Systems zur * 

automatisierten'Erzeugung von druckbaren Dateien; 

5 Fig* 2 eine methodische' Darstellung eines Aufrufes an 

einem SOAP -Server; • 

Fig. .3 - . eine method! sche Darstellung * eines Aufrufes- an 
einem SOAP 7 Server per SOAP; ■ 



Fig* 4 eine detaillierte Darstellung eines Aufrufes an 

einem. SOAP-Server fiber eine Apache SOAP API;' 

Fig. 5 die Darstellung einer Server- Proxy- Klasse 



In Fig* i ist der Aufbau des Systems zur automatisierten 
' Erzeugung von druckbaren Dateien anhand eines besonders 

bevorzugten Ausfuhrungebei spiels echematisch. dargestellt- Sin 
Drucksyetem 10 weist erf indungsgemaiS ein 
20 Druckauf tragerzeugungsmittel 15 auf . Das Drucksys tern befihdet 
sich beispielsweise faei einem Druckdienstleister, der Teil 
eines Mailingsystems ist, wobei das Mailingsystem 
elektronische Daten von Benutzern annimmt, aufbereitet und 
beispielsweise zu. Brief en, Postkarten und/oder E-Mails 
25 weiterverarbeitet * Die Daten von Benutzern und zugeh§rigen 
Auftragen sind zweckmafiigerweise in einer Datenbank 30 
hinterlegt, die sich au&erhalb des Bereiches des Drucksystems 
befindet. 

30, Druckdienstleister weisen typischerweise unterschiedliche 

Drucksys t erne .mit' spezif ischen Aiiforderungen' fur. verschiedene 
Drudkverarbeitungakonrponenten -14 auf, wobei die " • 
Daruckverarbeitungskomponenten beispielsweise prucker 11, 
Sortieranlagen 12 und/oder Kuvertieranlagen 13 umfassen 

35 kdnnen. Daher wird zur spezi f ischen Auf bereitung vori Daten ixn 
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Bereich.des Drucksy stems 10 erf indungsgem&£ ein 
Druckauf tragerzeug^ingsmittel 15 eingesetzt* Bei dem 
Druckauftragerzeugungsmittel 15 handelt es sich 
typischerweise um ein Programra, das vorzugeweise auf einem 
' s" Oder mehreren Computern des Drucksys terns 10 installiert ist. 

• Um dem Druckauftragerzeugungsmittel 15 und damit dem 

Drucksystem 10 Zugriff auf die Irihalte einer pat enbank 30 
auiSerhalb des Bereiches des Drucksystems zu ermoglichen, und. 

10 um diese Schritte zu automatisieren, wurde in einem besonders 
bevorzugten Ausftihrungsbeispiel der Erfindung eine Client- 
S^rvfer-Architektur gewaiilt, bei der 6oap als Kommunikations- 

. . Medium tiber das. Internet eingesetzt wird. Das 

Druckauftragerzeugungemittel 15 i'st.dazu uber eine erste 

is SOAP-Schnittstelle 40 mit ' einem SOAP- Server 20 aufierhalb des 
Bereiches des Drucksystems verbunden- Diese erste 
Schnittstelle wird vorzugsweise -fiber das Internet 60 
hergestellt Es k6nnen jedoch auch andere Verbindungsarten 
gewahlt werden> bei denen es sich um tempo-rare oder feste 

20 Verbintfungeri handeln kann. 

Eine SOAP-Schnittstelle weist gegenuber propria tiren , 
Kommunikationsprotokollen wis GORBA {common object request 
broker architecture) oder RMI <remote methode invocation) ■ 
•25 beispielsweise den Vorteil auf, dass bei der DatemSbertragung 
keine Konf.likte mit einer Firewall des 

Druckauf tragerseuguogsmittels 15 und/ oder des .Drucksystems 10 
•auftreteji. SQAP setzt dabei als Dat'en€fcertragungs-Protokpll 
vorzugsweise http/HTTPS ein. HTTP/HTTPS ist in einem Grofeteil 

30 der .Firewalls zugelassen oder uber proxys getunnelt, so dass 
eine Anpassung de^ Firewalls nicht notwendig ist, und keine 
neuen Angrif f spunkte geschaffen werden. ' Durch die Verwendung 
eines SOAP-Protokolls, das als gjrundlegendes Transport- . 
Protokoll das HTTP -Pro toko 11 einsetzt, ist femer eine 

35 einfache ubermittlung iiber das Internet. rndglich. 
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ttoer die SOAP-8otinittstelle 40 werden, alle Methoden" 
: bereitjgestellt:,, welche das Druckauf tragerzeugungsmittel 15 t 

zum. Erhait aller erf brderlichen Inf ormationert fur einen 
5" Druckauf fcrag aius d,er Datenbank -30 benotigt:. Zweckm&Sigerveise 
wird das' System gegen Fremdzugrif £e..£esi,chert ! Die Sicherung 
karxn auf verechiederie Weisen erfolgen. Beiepielsweise kann 
eine Authentif izierung des Druckauf tragerzeugungsmittels 15 
am Server 20, verwendet .wetden, .Vorteilhaffc ist- ferner die 
10 Verwendurig von HTTPS (HTTP Secure) als ' Obertragimgsprofcokoll . 

. Zugriffe des SOAP-Serve*s 20 auf die Datenbank' 3 0/ werden ' in 
einem besonders beybrzugten AusfOhrungsbei spiel H&r Erf indung 
liber 'ein.' PL/SQL-Layer " 40 ausgefuhrt.' Dadurch ist es unter / 
15 anderem i rhoglich, alle Datexibank'-Zugrif fe zu protokollieren 
oder bestinnnte Attribute zu setzen. Dies hat den Vorteil, 

dass eine. Konsistenzder Datenbank sichergestellt werden 
• kahn. 



20 



25 




Es bat sicb als zweckmaEig erwiesen, alle Statueanderungen 
ohne yerbindung. mi t dem Internet' am.: 

Druckauf tr agar zeugungsmittel vor zunehmen , und erfolgte 
Anderungeri daraufhin an den Server zu. senden.' Dies hat den • ■' 
Vorteil, dass das Druckauf tragerzeugungsmittel lediglich uber 
eine temporare. Varbindung mit dem Internet, verfugen : muss, und 
• auch dhne dauerhafte Interne tverbindung arbei ten kann. 
Lediglicb far- den Abgleich mit dem' Server muss, eine . 
Intemetverbindung aufgebaut werden. • 



30 



•Bin. Vorteil des erf indungsgemaSen Systems ist ferner,' dass 
" Updates f fir die • Konf iguration des •• 
Druckauf tragserzeugungsmittels zentral auf dem Server 
, hinterlegt werden konnen. In einem besonders bevorzugt en 

Ausftihruhgsbeispiel dear Erf indung iiberprilft das'. 
35 D^uckauftragserzeugungsmittel .beim Start, ob Updates 
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vorllegan und aktualisiert seine Konfiguration automatisch 
via JavaWebStart von dem zeatralen Server. 



xo 




is 



Besonders vorteilhaft ist es ferner, die. eigentliche 
KjDirarainikation ubeqr SOAP vqxi einer ; Apache SOAP API 
abzuwickeln. Die.. Abkurzung API steht £$lt Application 
Programming Interface , bei dem.es eich urn eine von einem . 
Betriebssystem oder, einem Anwendungsprograiran . vorgegebehe 
Scjhnittstelle handelt, ,tiber die anderen Anwendungen ' 
standardisierte Sof tiware-Tools zur Verftigung gestellt werden. 
Eirie .API ermdglicht also einem Ahwendungsprogramm, Funktlon 
und/pder Di ens te einer anderen software zu benutzerl. Im 
Ge^ensatz zu einer Dateischnittstelle ist eine API eine ■ 
sogenannte Call-Schnittstelle . Die Voteteile bei der Benutzung 
einer APT liegen . beispielsweise in der Senkung von 
Programmieraufwand und einer einheitlichen Benutzeroberf Iaclie 
und Funktionsweise. 



20 



25 




30 



.35 



,In Pig. 2 ist ein Ausffihrungsbei spiel • eines methodischen 
•Ablaufs dargestellt, bei dem das Druckauf tragerzeugungsmlttel 
15 eine Method© am Server 20 aufruft und nach. erfolgreicher 
Auefilhrung der. Methode ein Ergebnis als Ruckgabewert bekonnrit. 

*< ' • 

Methodenauf ruife per SOXp stellen sich. als XML-Nachrichten 
dar, die Ober HTTP versendet warden. Fig. 3 zeigt'den 
sctiematischen 'Ablauf eines derartigen Aufrufes., Das 
Druckauftragerzeugiingsmittel IS erzeugt eine erst e. SOAF- 
Nacluricht 16, in der angegeben wird, welche Methode* mit 
welchen Parametern \ auf geruf en werden soli . Diese SOAP- . 
Nachricht wird dann mit Hilfe dee HTTP-Protokolls ' Ober das 
•Internet 60 an der* SOAP-$erver 20 ; toertragen.' Diesef wertet ' 
.die Informationen und Daten aus.und gibt dann als zweite 
SQAP-Nachrxcht 17 ein Ergebnis zurttck. 

Im Detail fctellt sich der SOAP-Auf ruf- mit Hilfe der Apache ■ 
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. SOAP- API beispielhaft wie in. Fig- 4 dar. Das 
' Druckauftragerzeugungemittel erzeugt sine Instanz der Call- 
Klaese der Apache SOAP-API und setzt zunachst bestimtnte ■ 
Eigenschaften dieses ObjeJctes. In Pig., 3 sind beispielhaft 
5 verschiedene Methoden dargestellt, die von dem 

Druckauftragerzeugungstnittal .15 . aufgeruf en werden. . 

Eine Methode Tar 9 etObject~VRI entspricht beispielswesie einer 
, eindeutigen tmi, die auf der Serverseite im RPC-Router .einem 
xo . bestimmten Objekt zugeordnet ist (im Beispielfall dem . SOAP - 
Server) 

Bine Methode mapTypes wird vorzugsweise mehrmals aufgeruf en, 
um so eigene Klassen (beispielsweise UserJob, User) fiber das 
15 SOAP ubertragen zu kdnnen . 1 

" Ober eine Methode BGtMethodNewe kann der Methodenname • 
festgelegt und toer s&tParams eine Liste der Parameterwerte 
gesetzt werden. : 

20 

iSine Methode invoke ubernimmt dann den eigentlichen Aufruf 
per. SOAP. Es wird eine erste Nachricht 16 erzeugt und diese 
per HTTP an den Server 2 0 gesendet . 

i 

2S Es hat sich als zweckmafiig erwieaen, dass auf Seiten des 

. Servers 20- zun&chst ,ein Web-Server 21 die Anf rage annimmt und 
• : dieee auswertet. Bei dem Web-Server kann es sich 

beispieleweise "um Tomcat handeln. Um einen erf olgreichen 
SOAP-Aufruf zu. erm6glichen, ' muss einer gesendeten .URL das 
30 rpcrouteri\Servlet der Apache SOAP-API zugeordnet sein, dem 
■ v das Server-SOAP-Objekt' bekannt ist. Diesem Servlet yrird £er 
Aufruf ubergeben. Die AbkCtrzung ' URL eteht fur Uniform 
Ressource Locator. Ober eine URL sincl alle Dokuraente im 
Internet eindeutig addressierbaf. 

35 , * 
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Das rpcrouter-Servlet analysiert daraufhin die SOAP- 
' Nachricht, bestimmt die ■ auf zurufende Klasse und instanziiert 
diese. Danach wird die gewitaschte Methode mi t den ihbergebenen 
Parametem aufgerufen. Der m&gliche Ruckgabewert wird dann 
5 wiederum. i'n eine zweite SOAP -Nachricht 17 umgewandelt und 
diese ais Antwort per HTTP ziirdckgelief ert . Dafi 
clientseitige Call-Ob±ekt 18 analysiert diese Nachficht und 
. gibtdas entstandene Ergebnis an das 
Dxnckauftragerzeugungsmittel 15 zuruck. Im Fehlerfall kann 
io , hier gegebenenfalle ein Failure-Ob jekt abgefragt warden. 

, Mochtfc'.ein Dxnackauf tragerzeugungsmittel" 15 eine Methode am 
SOAP -Server auf ruf en, so kann es in einem weiteren besonders 
bevorzugten Ausfuhrungsbeispiel der Erf indung, eine 
is ServerProxy-Klasse verwenden. Ein Proxy-Server nimmt 

Anfbrderungen von einem Client entgegen und gibt sie, . 
gegebenenfalle ' modif iziert , an das ursprilxigliche Ziel zuruck. 

Ein derartiger Ablauf ist in Fig- 5 dargestellt. Der 
20 ServerProxy 22 kapselt die Apache SOAP API, und bietet dem 
Druckatiftragerzeugungsmittel alia Methoden des Servers. Ein 
Aufruf einer solchen Methode wird dann ttber die Apache API 
weitergegeben und der Rftckgabewert wiederum zuruckgegeben . 

25 Die SOAP- Ant wortnachricht wird analysiert und 

• im Fehlerfall eine Exception geworfen oder 

• im Erfolgsfall das Ergebnis zuruckgegeben. 

30 Die jeweiligen Methoden wandeln dann primitive Datentypcn, 
die. als Objekte zurCickgelief ert wurden, in den jeweiligen . 
primitiven Datentyp und, geberi diesen dann zuruck. 
Damit ist fftr das jeweiligc Dfuckauf tragerzeugungsmittel die 
SOAP-Komrnunikation nicht. transparent, sondern der ServerProxy 
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22 verhalt.. slch (bis auf die 1 anger en Lauf zeiten der 
Methoden), als rufe er lokale Methoden auf. 

Fur die Kommunikation wird in einexn besonders bevorzugten 
s Ausfahrungsbeiepiel der Erf indung das' RPC (Remote Procedure 
Call) gewahlt, RPC .gew&hrleietet einen entfernteh- 

• Fxuiktionsaufruf. Jeder Server in- einexn -Net z fetellt inv Rahmen 
dieses Konzeptes eine Anzahl von Diensten zur Verfugung, die 

' mit RPC angef ordert warden k6nnen. Diese Funktionen sind ale 
io prozeduren einee Programmes realisiert und k6nnen unter 

Angabe von Serveradresse, Programmnummer und Prbzedurnummer . 
*■'■ angesproehen- werden. RPC bietet die Mfiglichkeit, auf einfache 
' Weise Methodenauf ruf e und deren Parameter zu Obertragen. Das 
tfbertragen ganzer XML-Baume als Parameter oder ROckgabewert 
is wird dadurch nicht spezif iziert . Im Fall des SOAP-Servers 
wird vorzugsweise eine Erweitening der SOAP-Api Von Apache 
verwendet, die festlegt, wie XML-Baume Ober das SOAP RPC * 
fibertragen werden k6nnen. So konnen User Jobs als 

• Methodenparameter tiber die Apache SOAP-Api ubertragen werden. 



20 




Das SOAP RPC-Protokoll bietet femer die Moglichkeit, 
einfache Datentypen Wie String oder Integer zu Obertragen - 
Aber auch komplexe Datentypen kdnnen in Structa oder Arrays 
ubertragen werden, die wiederum aus einfachen Datentypen 
25 beetehen. * 

Bei der Kommunikation zwischen dem- 

Druckaurtragerzeugungsmittel 15 und dem" Server. 20 werden 
typischerweise verschiedene komplexe Datentypen ubertragen 
30 (beispielsweise LogicalProduct, IJser, UserJob) , Urn diese im • 
. SOAP RPC-Protokoll ubertragen' zu konnen, werden' 
zweckmafiigerweise Methoden implementiert , welche die Klassen 
als SOAP-Structs umsetzen und uragekehrt 

(Serialisieren/Deserialisieren) - Von der. Apache SOAP-Api wird 
35 . dieser Schritt jedoch vereinfacht, indem sie eine Klasse 
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•bereit stent, die diese-Funktionalitat fur alle Klassen, die 
einer javaBeans-Spezif ikatdon genCigen, - bietet . Deshalb .werden : 
die drei Datenklaesen • zweckmaSigerweise anhand der .JavaBeans- 
Spezif ikation implementiert und k6nn*n sorait auf einfache 
Weise fiber die SOAP-API ftbertragen werden-. Bei JavaBeans 
handeit es sich urn ein portables, Plattf orm-unabhangiges 
Componentmodel, das in Java geschrieben ist . . . \ 

: Itn ,'Folgenden wird;beispielhaf t einbesbnders vbevorzugtes 
AusfQhrungabeispiel eines Druckauf tragerzeugungstnittels, das 
in einfem Drucksystem installiert ist, dargesteilt. Besonders 
' vortSiihaft ist die AusfOhrung des •• , . 

Druckanftragerzeugungsmittels in Form einer XML-Kqnf iguration 
Mit einer derartigen Konf iguration kahn de± gesamte 
is' . Produktionsablauf beim-Drucken gesteuert werden. Die . 
Bedienung erfolgt zweckmaEigerweise uber eine grafische 
Benutzerbberflache, uber die' beispielsweise Aktionen 
' ange.stoSen und Parameter eingegeben werden. Die druckbaren • 
Dateien konnen automatisiert ;zu einetn Produktjionsdrupker 
20 ubermittelt werden. , • ' 

Mittels des Druckauf tragerzeugungemittels kann ein 
Drucksystem beispielsweise ihm zugewiesene Auftr&ge.aus einem 
" » Mailingsystetn auf eigene lokale Systeme transferieren, sowip 
den Bearbeltungsstatus an das Mailingsystetn zurftckmelden . Das 
Druckauf tragerzeugungemitt el nimcrit ..als lokale Applikation 
zugleich die; zentrale Funktion der Druckdatenaufbereitung. 
wahr..Die.DrxiGkdatenaufbereitung kann beispielsweise folg^nde 
Punktioiien umfaesen: 



- Aufbereitung' von Auftragsdateii'lm XML-Format zu 
durchsatz-optimierten Druckmafichinen- und 
Finiskihgspezi£ischefi Druckjobs. 

135. - Zuearranenfassung einzelner Druckjobs. 
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Umwandlung von Druckjobs in axidere Formate, sofcm ".■ 
eineDruckmaschine dieses . Format ben6tigt ; , . 

Druckjobs mit maschinenspezif ischen Steuerzeichen zur 
automatislerten. Verarbeitung' verseli.en. Dabei kann es . 
sich beispielsweise aim Barcodes' handeln. ■ 

Generierung von" ReprintB,, ura b'ei Produkticriief ehlern 
die Nachi>earbeitting einzelner Send'ungen 'zu 
ermSglichen. ' 




Die Konf igurat ion das Druckauf tragerzeugungsmittels besteht 
is zweckmaJSigerweiee aus Modulen, -^irtuellen Druckern und 
Settings. 

In den Settings werden allgemeine Einstellungen wie z.B- 
pfade und Kommunikationsparameter konf iguriert . 'Die Parameter 
20 konnen ttb.er eine Benuzeroberflache des ( >; . . 

1 Druckauf tragerzeugungsmittels verandert v/erden. In der . , 
: f olgenden. Tabelle ist beispielhaf t die Bedeutung/Funktion * 
einiger moglicber Setting-Parameter auf gel istet:' 




Parameter 


Funkflon 


http.proxy. 


„true u oder „faise" besfimmt, ob die internet-VerbindOng 
Ober einen Proxy erfoigt. 


http.proxy.host 


Proxy Host-Name 


http.proxy.port 


Zu benuteener Port fOr die Kommunikatlon mit dem Proxy 


http.proxy Joginbox 


n true 11 oder ..false" bestirnmt, objclie BenutzeroberRache 
eine loginbox bei der Anmeidung am Partner-Server 
anzeigt, Jn der man Usomame und Password fOr den Proxy 
angebeh kann. : 1 i . , ! 


http.proxy.user 


Username fur Proxy-Anmeldung 


http.proxy.passwd 


Passwort TOr Proxy-Anmeldung 


soap.protocol 


Das zu verwendene Protokoll fdr die SOAP-Kommunikation. 
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soap.host 


Belspielsweise werden „http" und „https" unterstOtzt . 
Host-Name des SOAP-Partner-Servers 


soap.port 


Der zu verwendene Port fur die SOAP-Kommunlkation. 


soap,path 


Der Pfad auf dem SOAP-Partner-Server 


.soap.serviceid 


Die ServIcelD auf dem SOAP-Partner-Server 


http.auth 


"true" Oder ..false", bestimmt ob 


http.auth.user ; 


Username fur HTTP Authentlfizrerung 


http.auth.passwd 


Username fOr HTTP Authentffizlerung . 


site 


Name derProdukttons-Site 


Instanceid 


inc+rtnr-Ain derverwendeten Instance. DIentzur Benutzung 
mehrerer Rechner an einer Site 


basepdth 


Basis-Verzelchnis- 


outputpath . 


Ausgangsverzeichnls fOr die erstellten Dateien 


ternppath 


Verzeichnis, in dem temporare Dateien angelegt werden 


queuemanggerpat 
h 


Verzeichnis, in dem ein Queue Manager seine Dateien 
ablegt " * 


enrorpath 


Verzeichnis, in dem die error log Dateien abgelegt werden 


partnerid . 


Partner ID des Druckdienstleisters , 


rarTnernarne 


Kinmp Hn<; Dm<r kdlenstleisters 


parrnersTreeT 


ctrnccp Haq Hn jekdienstleisters 


partnerpc 


Postleitzahl des Druckdienstleisters 


partnertown 


Stadt des Druckdienstleisters 


wamingdays 


Anzahl der Tage, nacnaem em userjoo. an aessenon-nw 
sich nichts geandert hat, in der Bertutzeroberflache 
belspielsweise gelb werden soli 


compatibility 


Muss auf "false" stehen 


archivesample 


Anzahl von Adressen, ab der fOr einen UserJob 
Belegexemplare produaert werden sollen . 


pdflibseria! 


SeriennUmmer fOr die PDF-Lib 



Zur Erstellung von druckf ahigen" Dateien aus einem PrintJob 
' XMIi-File hat es sich ale zweckm&Sig erwiesen, einen PDF- 
s Kernel vorzusehen, Auf welche Weise die dmckfahigen Dateien 
pz-oduziert werden, ■ ist durch. eine Konf igurationsspraclxe 
beschrieben, Dem Kernel wird von der Oberfiache nur eine 
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• Print Job XML-Date i und ein zu benutzender virtuelle Drucker 
mitgeteilt. ... 

. Die Druckauf tragskomponente bekommt zur Erzeugung von 
5 Druckdaten Auf tragsdaten, die beispielsweise axis einem 
Template im PDF -Format und variablen Daten far die 
Personalieierung und Metainformationen im XML-Format 
bestehen. Mithilfe einer 1 extsrnen PDF-Library, die sich 
beispielsweise in der Datenbank 30 bef inden -kann, erzeugt das 
io : Druckauftragserzeugtingsmittel schlieSlich fertige PDF- 

. Dateien. Die Art der Erzeugung h&ngt von den Auf tragsdaten 
; ' \md von, bardwareunabh^gigen "Metainformationen, wie zum 
pei spiel QrSEe der Druckjobs # Sqrtierung nach postalischen . 
Kriterien, Begleitscheinanweisungeh fGr die* Postauslief erung 
is und/oder Beilagen ab. Sie erfolgt ferner in Abhangigkeit von 
hardwarespezif ischen Metainformationen wie AusschieiSen, 
Performance-Optimierung und/oder spezif ischen Barcodes , die 
iri den- virtuellen Druckern konf iguriert sind..'. 

20 Die Art der Erzeugung h&ngt aufierdem davon ab, wie die 

Verarbeitung definiert 1st. Das Druckauftragserzeiigungsmittel 
ist daher auch ein Interpreter, der seine Logik aus einer 

• Verarbeitungsdatei vorzugsweise im XML-Format bezieht. Soli 
ein Druckauf tragserzeugungsmittel beispielsweise atatt 

25 Postkarten aufklappbare Grusskarten mit einem einseitigen 
Anschreiben erstellen k6nnen, muiss lediglicb die 
Verarbeitungsdatei angepasst werden. Dies passiert an 
zentraler Stelle des Mailingsystems und beim nachsten Start 1 
wird die 'Anderung automat isch an das " 

30. Druckauf tragserzeugungsmittel tibermittelt, so dass das 
'■*. Druckauf tragserzeugungsmittel nun Grusskarten- mit einseifcigem 
Anschreiben erstellen kann* ■ 

Die M6glichkeiten, ein Dokument zu produzieren, sind sehr 
35 vielfSltig und hangen von diversen Faktoren wie 
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Auegangsf ormat , gewunschten Farben, zu bedruckendem 
Papierformat / Bndverarbeitu^g iind verwendeten Druckem ab* Um 
zu beschreiben, wie ein Dokument far einen konkreten Pall zu 
produzieren ist, wird der Begriff . „Virtueller Drucker 1 * 
S eingefuhrt. Bin virtueller Drucker beschreibt dabei, unter 
welchen Vorraussetzungen ein /Dokument mit ihm produziert 
'.. ' ' werden kann und wie das Dokument fur diesen- konkreten Fall ■ 

aufbereitet wird, • * 

• **»•,*' ' * 

*■ . ■ - 

,•10 Es ist mdglich, dass verschiedene ■ Dokumerite mit dem gleibhen 
• virtuellen Drucker 'produz'ierbar sind, beisjoielsweise k&nnten 
sowbhl Farb'-, ale auch Schwarz^WeiS-Dokumente bei gleicheir 
. Aufbereitung mit eiiiem Farbdrucker erstellt werden. Es ist 

moglich, dass verschiedene virtuelle Drucker den gleichen 
' is physikalischen Drucker zum Druck benutzen, beispielsweiee 

kdniien' Dokumente mit dem Ausgangs format .DIN A4 sowohl auf DIN 
A4 als auch auf DIN A3 mit> aris'chliefiender Endverarbeitung 
gedruckt werden. Die beiden Salle bedurfen unterschiedl i cher 
Aufbereitung der Dateien und tmlssen deshalb mit 
20 unterschiedlicben virtuellen Druckem aufbereitet werden. 
Beide virtuelle Drucker konnen aber die Dateien zu dem 
gleichen physikalischen Drucker schicken, falls er DIN A3 und 
DIN A4 bedrucken kann. ■ ( 

25 Die virtuellen Drucker werden in der Konf iguration erstellt, 
und vom PDF-Kernel bei einer Print Job Produktion schrittweise 
abgearbeitet . 

Zu Beginn der Produktion wird dem Kernel der zu verwendende 
30 ' virtuelle. Drucker mitgeteilt. Danach wird die PrintJob XML- 
Date i eingfelesen, woraus die internen Datenstrukturen , • die 
'fur die weitere Produktion notwendig sind', aufgebaut werden. 

* Wahrend der geeamten. Produktion merkt sich' der 
35 Produktionskernel, welche Brief seite sich auf den erstellten 
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S«Lt:en cter' PDF-Dokumente befindet. Mit einer Funktion 
CreateTempl&tePDF kann der -statische Teil fur die Produktion • 
erstellt werden. Dazu mussen leere Seiten pereonalisiert 
warden .. Warden di'ese personal ieierten Seiten auegesehossen, . 
merkt sich der Kernel, wo die einzelnen Brief a positioniert 
werden. Die personalisierte PDF-Datei kann beliebig, verandert 
werden! Dazu zahlt beispielsweise das Hinzufugen von Seiten, ; 
die Anderung der Seitenreihehf olgen, das Hinzufugen von. 
'Teacten und Linlen und .das AusschieSen . fcediglich 
ausgeschossene Dateien durfen nicht erneut ausgeschossen 
werden. Wenn die personalisierte PDF-Dat;ei (Variabler Teil). 
ferfcig verarbeitet ist,.kann mit. createrengplat'ePDF eine dazu 
passende statische PDF-Datei erstellt werden. Dabei wird aus 
den PDF-Vorlagen aller UserJobs- eine PDF-Datei erstellt, in 
der alle notwendigen Kombinationen einmal vorkommen. Zur 
gpateren Brstellung eines Job-Tickets- .fur 'einen 
Produktiotisdrucker wird eine . Datenstruktur aufgebaut, die. 
•beschreibt, .-welche variable Seite zu welcher statischen Seite 
passt . ' ' '. " 

Attribute vort createTeaplatePDF sind beispielsweise folgende: 



Attribute 


Funktion 


PageWldth 


Seitenbreite der zu erstellenden PDF-Voriage. 


PageHeight 


Seltenhohe xter zu erstellenden PDF-Vqrlage; t 


VariableRleName 


Personalisierte PDF-Datei; fur die eine statische Vorlage erstellt 
werden soIL .•' 



30 



Eine Funktion Condition kann als' Attribut bei manchen 
Funktipnen verwendet werden, damit" .diese unter bestiromten 
Bedingungen ausgefuhrt werden. Folgende; Anweisungen* werten 
Condition aus: „AddText*\ .„Addliine w . und „NewPDF>" - • ■ 

Durch die Angabe eines Schlueselworts' kann die* Bedingung, bei 
der die Anweisung erfolgen soil, spezifizierfc werden. 
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FolgendeSchltisBelw&rter kdnrien' beispielsweise iirtplementieirfc 




werden : ; • • 


Schlusselwort 


Funktlon I 


ddArchiVe 


Wird nur ausgefOhrt, wenn 
RoipnovAmninre aedruckt werden soli en 


IntemaLcustomer 


Wlrd nur ausgefuhrt;. wenn der B^nutzer 
Hft* LkerJobs ein internet Benutzer ist. 
Liefert Immer false. * 


externaLeustomer 


wvh ni ir ausaefOhrh wenn der Benutzer 
des UserJobs ein externer Benutzer ist, 
Ueferf immer true. 


ContainsCurrentlnfoPostCri+eria 


Wird ausgefuhrt* wenn es Briefe fOr das 
gesetzte Infopost-Kriteriuni glbt. 


•Contaln5Currer»tInfoPostCriterialnLoo\ 

ITS ' ' 


Wird ausgefOhrt, wenn Innerhalb eiher 
Loop ein gesetztes Infopost-Kriterium 
vorhandenist ■ 


^tar+OflnfoLetter ' 


Wird ausgefuhrt, wenn innerhalb der Loop 
der Start der Infbbrief Bfiefe ist 


Minnie* User Job 


Wird ausgefOhrt, wenn in diesem Print Job -> 
nur ein UserJob enthalten ist 


Mi il+Tnl<»l ke»r lobs 


Wird ausgefuhrt, wenn in diesem PrintJob 
•mehrere UserJobs enthalten sind 


" t 


Wird ausgefOhrt, wenn innerhalb der Loop 
das Ende der lnfobrief Briefe ist 


StartOflnfoPost . 


Wird ausgefOhrt, wenn Innerhalb der Loop 
der Start der Inf opost Briefe- ist 


EndOflnfoPost.. 


Wird ausgefOhrt, wenn innerhalb der Loop - 
das Ende der Infopost Briefe ist 


StartOfStdndard'. 


Wird ausgefOhrt, wenn innerhalb der Loop 
der Start der Standard Briefe ist 


EndOfStandard 


Wlrd ausgefuhrt, wenn Ipnerhalb der Vqop 
das Ende der Standard Briefe'ist 


Cqntairnslnfpletter 


Wird ausgefOhrt, wenn sich in dem PrintJob 
lnfobrief Briefe befinden 


Coritaihslnfopost 


Wird ausgefOhrt, wenn sich in dem PrintJob 
Infopost Briefe befinden 


ContainsStandard * 


Wird ausgefOhrt, wenn sich In d$m PrintJob 
Standard Briefe befinden 
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Innerhalb einer Funktion SendToPx-inter kann ein Rip-Ticket . 
.ersteilt, die PDF-Dateien gewandelt und die fertigen Dateien, 
zu eineni Drucker geschickt wercien. 




Mit feiner Funktion OreateRipWcJcet wird koiif iguriert , wie ein 
Rip-Tibket zu eretellen ist\ Als Attribute muss Filename mit 

10 dem Zielnamen' gesetzt werden. Innerhalb von CreateRlpTlcket 
werden mit DcttaLine& zusammengef asst mehrere Line- 
Beschreibungen ersteilt. Innerhalb von Line wird das 
■ Attribute Data gesetzt . Alle Texte von Line werden . 
nacheinander ins Rip- Ticket -File geschrieben. Dabei werden 

13 angegebene Variablen ersetzt.'An beliebigen Stelleil konnen 
Repeat- und Loop-Schleif en eingebaut ©ein.. 

Bei eineni UserJob mit der ID 10000105, bei dem sich acht 
variable PDF-Seiten bilden f entsteht z.B. folgende Rip- 
20 Ticket -Datei : 




25 



30 



35 



40 



Book Ticket Pile created by Mailingfaatory - SIMPIjEX 



BOOK bookj.0000105 

»M_10000105 U .(1) <§J»V 

«M_10000105" (1) ®"V" 

«M_10000105" (1) © n V 

«M_10000105" (1) @«V 

w m_iooooio5" (i) ® n v 

n M_100001Q5 n (2) <3>"V 

"M_10Q00105.« (1) ®»V 

»M_10000105" (3) @"V 

BNDBOOK 



10 000105 JD M (1) 
"l0000105~0" (2) 
"l0000105_0« (3) 
"l000010S_0« (4) 
"i00001Q5__0" (5). 
"lb000105_0 n (6) 
*1000010S_0'« (7) 
"10000105 0" (8) 



PRINTRUN px7_10000105 

. ,book_10000l05 f . bcopies«l 

ENDPRINTKUN 



Mit einer Funktion Convert konnen die PDF-Dateien 
beispielsweise in ein Format wie Postscript konvergiert 
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werden. Mogliche Attribute von Convert sind: 



Attribute 


Funklion 


Method 


Die Konvertierungsm.ethode. 


ProgramTbUse 


Name des Konvertierungsprogramms. 


Printer 


Der Drucker, der fOr die Konvertierung nach PostScript 
verwendet werden soil 


DeletelnputFiles 


Optional, true oder false. Bestlmmt, ob die Bngangsdateien 
nach der Konvertierung geloscht Werden sollen. 




3.0 



Mit einem Tag NewPS yird das Druckauftragerzeugungsmittel 
angewiesen/ eine PDF-Datei beispielsweise nach PbstScript zu 
konvertieren. Tags aind Begrenzerzeichen f ur Bef ehlsangaben 
in HTML*. Bin Attribut von NewPS in Convert kann InputFilename 
sein: ' " ■ . 



Attribute 



Funktion 



inputFilename Der Name der Patei, die konvertiert werden soil 




xs Nit einer Funktion Sexxdfile koxmen Datei en direkt zu einem 
Drubker gescbickt werden. Attribute von Sendfile sind 
moglicherweise folgende; 



Attribute 


Funktion 


Command 


Das Kommando; mit dem die Datei zum Drucker geschickt 
werden kann 


Filename' . 


Die* Dafei. die :zum' Dru.cker geschickt werden sol! 


Delete 


Wenn dieses Attribut vorhanden ist, wird die Datei nach dem 
Versand automatisch geloscht. . 



20 
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m der Konfiguration dea Druckauf' ^tragerzeugungsmittels k6nnen 
beliebig viele virtuella Drucker angelegt werden,.!* einem 
virtuellen. Drucker wird konf iguriert, welche Jobs mit dxesem 
Virtuellen Drucker bearbeitet warden konnen und wie die 
Dokumente erst ell t werden sollen. Bin virtueller Dicker hat 
beiBpielsweise folgenden Aufbau: 




10 



is 



20 



25 




30 



<:V±rtualPrinter Name- "DP 
Description="Bine DUX A4-PDF 
< pr int JobCondi t ions > 


gXMPLEx* AddxQseesPerPly= "200* 

mit Addresaen und Template in einem" > 


<; / PrintJobCondi t ions > 
«Prepare JobDocuments > 




</prepareJobDocuments> . 
<S*endToPrinter> 




</SendToPrinter> * 


• 



Die Attribute von VlrtualPriater k&zaien beispielswaise wie 
folgt auesehen : 



Attribute 



Funktlon 



Name 


Name des virtuellen Druckers. Dieser wird zweckmQBlgerweise in 
der Benuteeroberflache angezeigt und sollte Aufschluss uber die 
Funktion geben 


AddressesPerPly 


Anzahl der Adressen, die bei der verdeckten Aufteilung der 
PrintJobs pre Schritt verarbeitet werden. 


Description 


Kann genutzt werden, um eine genauere Beschretbung fOr 
spatej-e Lesbarkeitzu hinteriegen. 



• bber PrlutilahConditiohs kann/geregelt werdeft, welche Jobs mit 
; diesem virtuellen Drucker produzierbar sind. Hier k6nnen 
Name -Value Paare angegeben werden, v^obei.der Name einem 
35 usercrob-Attribut entsprechen muss. Der Wert in Value gibt an> 
welchen Wert das Attribut haben.muss, damit der UserJob rait 
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diesem virtuellen ijrucker produzierbar ' ist . Sobald eine 
Bedingung" nicht zutrifft, isti der User Job nicht mit diesem . 
• virtuellenj Driicker . produzierbar i User Job -Attribute , die nicht 
unter den PrintJobConditions ang^geben sind, k6nnen beliebig 
sein, " • 

Innerhklb von PrepareJobDocxments k6nnen beliebig viele 
PrepareDocvmentSteps angelegt werden'. Diese ' Schritte werden 
nacheinahder' ausgefuhrt, uxn die Dokumehte zu produzieren, 

Innerhalb von PrepareDocumentStejp wird beschrieb'en, wie' eiri 
PDF-Dbkument er&tellfr wird. . Dieses Dokument kann'auoh in 
weiteren Schritten als Vorlage verwendet werden* Irmerhalb 
von Pr&pareDocvmetStep konnen Loop, repeat und NewPDF 
verwendet: werden. Es kanii auchein Modul angegeben werden, 
dessen Inhalt wie, folgt ausgefuhrt' wird: 



<PrepareDocumeritSfep Name="Create InfopostCriteria StartPage" 
Module- n Startpage Infopostcriteria simplex w /> ; 



20 



25 



Auch auf der Ebene von settings und Virtual Printer Ic&nneri 
Module angelegt werden. Diese konnen von mehreren 
PrepareDoOTJnentS.tep-Eintragen in verschiedenen virtuellen 
Druckem referenziert werden. 




/ Innerhalfo einer Jtoop-Schleif e werden all© darin enthaltenen 
Befehle wiederholt. Die Anzahl der Wiederholungen richtet.' 
• sich nach der Einstellung voji AddresaeBPerPiy im virtuellen 
30 Driicker i^ndnach d^r Anzsihl der Adressen indetn Print Job 

(NumberOf Pieces) . .Die Schleife wird so oft wiederHolt, wie 
AddreBsesPerPly Lxi NumberOf Pieces passt. Bei einem Rest wird 
zweckmaEigerweise auf genindet . 



3S loop wird beispielsweise benutzt, um ein „verdecktes 
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jobsplltting" durehzufflhxeni Bei ainem Loop-Durchlauf wird 
sine variable LoqpNo in. jedetn Schritt gesetzt, Dieee. Variable 
kann benutzt werden, um verechiedene Dokumentnamen zu 

.• . . .•'•,> 
erzaugen. - . • , 

■ . - ' • * ' , 

Repeat kann benutzt werden, um Anweisungen mehrfach. 
durchzuftihren; Die Anzahl der' Wiederholungen kann 
paramet;risiert werden, Wahrend des Durchlaufs wird die / 
Variable R&peatNo geaetzt.' Die. Attribute von Repeat lauten 
beispielsweise wie folgt: 



Attribute 


Funktion 


Start 


Der Anfangswert von RepeatNo 


Count . 


Die Anzahl der durchzufuhrenden Durchlaufe 


Action 


Optional, kann benutzt werden um bei jedem Durchlauf 
Urrigebungsvanablen abhangig von RepeatNo zu set^en. UnterstOtzt 
werden beispielsweise: 

f1 SetCompany" -> kann benutzt werden, wenn ein PrintJob aus 
mehreren UserJobs verschiedener FInnen stgmmt, urn durch die Rrmen 
^uiterieren. 

nSetlnfoPbstCriteria" -> kann benutzt Werden, um durch die 
verschiedenen Infopost-Kriterien zu iterieren t • • 

„SetCompanyUserJob->.kann benutzt werden, um fur durch die 
UserJobs der Company zu iterieren. . 




*5 
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Mit NewPDF kann ein neues PDF-Dokument erstellf werden. 
Innerhalb von NewPDF nriissen Anweisungen erfolgen, wie das . 
PDF-Dokument erstellt werden soil- Folgende Anweisungen sind 
beispielsweiee innerhalb von NewPDF moglicb: ^Repeat'™ , . 
//Workflow 1 "', ,,PersonalizeOnTemplate*, „ Personalize*, 

.„Cr : eateTe^^plateFDF , *' und „OpenPDF", 

' 1 * " * » ■ ' 

< ' . * . . . ... 

NewPDF kann folgende Attribute besitzenr 



Attribute Funktion 
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Rename 


Name der zu erstellenden PDF-Datei 


Persistence 


Gibt an, ob die zu erstellende Date! nur tempor^e»sner©n wll. 
Oder nach Beendigung der Produktlon erhalten bleiben soli. 

Werte: 

.Jemp" -> Die Datel wird nach der Produktion geloscht. 
,, Final" -> Die Datel bleibt erhalten 


Condition- 


Optional, _ — _ ^- 





Ee'hah sich als besonders vorteilhaft erwiesen, Workflows zu 
' verwenden, in denen beschrieben wird, wie ein Dokument zu 
s e'rstellen ist. Innerhalb von Workflows konnen beispielsweise 
VarlableData, Merge und Impositioning • erlaubt sein. Workflow 
besitzt zveckmafiigerweise keine- At tribute. , Sind mehrere 
Workflows nacheinander angelegt, so werden diese 
beispielsweiee nacheinander abgearbeitet , wobai das Ergebnie 
10 exiles * Workflows immer als Quelle des n&chsten Workflows . 
dient . 

' * . 

Ein Befehl PerBonallzeOnTemplate bewirkt, dass eine neue PDF- 
Datei entsteht, in der sick nacheinander mehrere Brief e 

is bef inden, die aus der PDF-Vorlage bestehen und mit den 

Datensa,tzen aus deri variablen Daten personalisiert sind. Die 
Anzahl der Brief e richtet sich nach dem Attribut 
AddressesPerPly. Urn fur alle variable Daten Briefe zu 
* generieren, muss Personal! zeOnTemplate innerhalb von Loop 

20 ' ers.cheinen. Dadurch entstehen mehrere PDF-Dateien mit jeweils 
einer.Anzahl von AddressesPerPly-Briefen, Ist die Anzahl der 
Adressfcn nicht genau durch AddresaesPerPly tei-lbar, bef inden 
sich in der letzten PDF-Datei die restlichen Briefe.' Bef inden 
sich verschiedene User Jobs in dem Print job, wird automat i sen 

23 die zu deir jeweiligen Adresse passende .PDF-Vorlage benutzt. 

Zur Klassif izierung von Postsendungen werden. Hblicherweise 
Infopostkriterien festgelegt, die. beispielsweise Infobrief, 
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infopost Oder Standard umfiassen kfinnen. Wird wahrend der 
Personalisierung ein derartlges Infopost-Kriterium gesetzt, 
warden nur Adressen, die' das . entsprechende Inf opost-Kriteriutn 
besitzen, behandelt. . 

Ein 'Beisplel dazu ist im Folgenden dargestellt : 



<PrepareDocumentStep Name- "Personalize on Tamplate"> 
^Repeat Count="3" Action-* Set Inf oPostCriteria" ' Start- "1"* 

FileSmS^ » $ {TEMPPATH} \new_$ { JobIJ>}_$ {LoopNo}_Pers_$ {RepeatNo} » 

Persistence^ 1 Tenip"> „. . • * - v. 

<PerBonali Z eOnTemplate ■ StartPage=»l« .PageWidtb-»210' 

PageHeight» " $37 n / > 
*/N<awPDF> 

</Repeat> 
</Loop> 

</PrepareDocumentStep> , ; . — , r 



Durcb die obigen Anweisungen entsfceheri mehrere PDF-Dateien im 
Tempp&th mit dent Natnen new_lD_xJPerB_y, mit f olgender 
Bedeufcung: 



X: Index zu ErkSnnung des Teilpaketes. Lauft.von 0 bis 
„ InitialNumberOf Pieces H /^AddresseePerPly w 
(Aufgerundet) - 

Y: Dae jeweilige Inf opost-Kriterium. it Infobrief; 2: 
30 ' Infopost; 3: Standard. 

Die Summe aller Briefe aus den verschiedenen infopoat- 
•Kriterien bei- einem Wert £ to X ist gleicb AdciressePerPly 
be^iehungsweise dem ReBt der Teilung. 



Vorteilhaft ist femer eine Funktion Personalise, diewie 
Personal x&eOnTenplate funktioniert , au£er dasa nicbt auf der 
PDF-Vorlage, eondern auf einem neuen leeren Dokument 
personal isiert wird. Attribute von „ Personalize* konnen 
belspielsweise wie folgt auasehen: 
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Attribute 



PageHelght 



Funklion 



Seiten-Breite der neu zu erstellenden PDF-Datei 



Selten-H6he der neu zu .ersteilenden PPF-Datei 



Eine Funktion OpenPDF bewirkt, dass eine PDF-Datei ge6ff net 
wird. Diese Date! dient bei weiteren Anweisungen ale Quelle, 
Ein Attribut von OpenPDF ist beli spiel aweise Filename; 




Attribute 



filename 



Funktion 



DerDateiname komplett mit Pfad von der zu Sffnenden Date! 



Vorteilhaft ist femer, dass mit VariahleData zusat?sliche 
Daten auf ein FDF-Dokument aufgebracht werden k6nnen. Als 
Vorlage dient hierbei das gegenwartige Dokument, welches 
entweder durch OpenPDF geoffnet wurde, aus dem vprherigen 

is Workflow stamcnt, oder innerhalb des momentanen workflows 
zuletzt entstand. bazu muss ein Seitenbereich angegeben 
werden. Auf diesem Seitenbereich werden die innerhalb von 
VariaJbleDafca angelegten Befehle ausgefiihrt. Innerhalb von 
VariableData ist „AddText", „AddSDL", „AddLine* und w AddOMR v 

20 'mfigllch.* 

•Attribute von VariableData sind beispielsweise: 



Attribute 


funktion 


Name 


Kann zu Sezelchnung verwendet werden • 


StartPage 


Start-Seften des Seftenbereichs, auf dem gearbeitet werden soli 


EndPage 


End-Sefte des Seftenbereichs, auf dem gearbeitet werden soil 


Step 


Die Schrittwelte fOr den Seitenbereich. Soil z. B. nur jede zweite Seite 
bearbeitet werden, so ist 5tep=2 
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Mit Fvmktionen'wie 'StartPasre und EndPetffe konnen auch 
m^tlieTnatische'Aiiweieungen erfiolgen. Be k6nnen .beispielsweise 
'5 . folgende Zeichen xmtersti&tzt warden: , 




Zeichen 


Funktion 


n 


Klammerung 


* 


Multfplizieren 


/ 


DIvidieren • 


+ , 


Addieren 




Subtrahieren , . ' " 


% 


Modulo 


first 


Schlusselwort fur qfie erste Seite -> 1 


last 


SchlOsselwort fOr die letzte Seite des bokuments. 



Dabei funrt Endpaga** *>last/2+l* beispielsweise dazu, daes die 
10 Seiten bis ' zur mittleren geraden Seiten bear-beifcest werden. 

Innerhalb von Va^riableData karui eine .Funktion AddText benutzt 
"werden, Urn einen Text hinzuzuf xlgen ; . , 




Attribute 


Funktion 


Data 


Text-String; der elngefbgt werden soil 


Rotation 


Text Ausrichtung. M6glicheWerte beispielsweise 0,90,180,270 


Color 


Farbe, mit der der Text dargestellt werden soil. Mogliche Werte: 
black, blue, red, green, cyan, magenta, yellow; white 


FontSize 


Die Font-GfoGe in pt 


xPos 


Textstartpunkt in horteonfaler Richtung, gemessen yom linken 
Seitenrand. EInhelt: mm 


yPos 


Textstartpunkt in vertikater Richtung, gemessen yom unteren 
Seitenrand. EInhelt: mm 


Font* 


Der Font, mit dem der Text dargestellt werden soil. Z.B.: 
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1 1 

I 

" 


TlrnesRoman . Helvetica •• . . Courier Symbol 
TimesBold . HelveticaBold CourierBold 
Tlmesltalic HeWetlcaOblique • ' CourlerOblique 
TfmesBoidltalic HelvetlcaBoIdOblidue.* CourierBoldObjique 
ZapfDingDaTs 

.* ■ • i 


ReplaceData 


TRUE Oder FALSE: . D©STimmT, od a©r i©at gsypuiai wc?h-*^m ^vh/ 
darhit Van'ablen erkannt und durch Ihr© Werte ersetzt werden. 


Condition 


Optional, 


CharSpacIng 


Optional, glbt ah, wis viele Leerzeichen zwlschen alle Zeichen ■ 
Innerhalb des Text-Strings elngefOgt werden sollen 


MdxLength 


Optional, begrenzt den Text-String aof die angegebene Anzahl 
von Zeichen; 



Bine Punktion AddLine kann. lnnerfialb'. von VarlableData benutzt 
5 werdeni urn eine Linie zwischeri zwei £>unkfce hinzuzufttgen:. 




Attribute 


Funktion 


xStart • 


Startpunkt der Linie in horteontaler Richtung,' gemessen vom linken 
Seitenrand. Snheit: mm. 


yStart 


Startpunkt der Linie In yertikaler Richtung, gemessen vom unteren 
Seitenrand. Einbeit: mrrv 


xEnd 


Endpunkt der Unie in horteontaler Richtung, gemessen vpm linken 
Seitenrandl Einheit mm. 


yEnd" 


Endpunkt der Unie in yertikaler Richtung, gemessen vom unteren . 
Seitenrand- Einheit: mm. 


Thickness 


Dicke der Unie in mm. . 


Color 


Farbe. mit der die LIntedargestelit werden salt. Mqgllche Werte: 
black, blue, red, green, cyan, magenta, yellow, white 


Condition 


Optional 


* 


■ ^ 

* ■ * 

M ■ . 



id Eine Funktipn AddOMR kanri iraerhalb von V&zriahl eData benutzt 
werden, urn auf Seiteri OMR-Steuerzeichen hinzuzuf ftgen: 
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Attribute 


Funktion | 


xPos . 


<i+or+ririnid- fnben/links* der Steuerzeichen in. horizbntaler Rlchtung, 
gemessen vom linken Seitenrand. Qnhelt: mm: 


yPos 


Siartpunkt (oben/links) der Steuerzeichen in verlikaler Richtung, 
gemessen vom rechten Sertenrand. Einheit: mm. 


Sequenz 

» * 


Bestlmmt die zahlweise der BS-Striche.UnterstOtzt werden: 0-7, 1-7, 7-1 
und 7-0, Wird z. B. 0-7 verwendet, dann nehmen die BS-Striche 
nacheinqnderfolgende Werte on:. 

BS1:01 01 01 0 1 

BS2:001 1 00 1 1 

BS4: ooooiiii : 


LineWidth 


Striphstarke der Steuerzeichen in mm. 


Width 


Strichlange der Steuerzeichen in mm 


Dabel tnus 
AddOMR ei 


& fuf jeden Steuerzeiclien-Strich. irmerhalb von 
n ^Xiine^-Tag hinzugefftgt werden. 


1 Attribute 


Funktion 


Name 


Kann verwendet werden, urn Strichfunktion zu beschreiben. 


Position 


Die Position Innerhalb der Striche. Die erste Position ist an der durch 
xPos und yPos bestimmten Stelie. Nachfolgende Positionen llegen 
jeweils 1/6 Zoll weiter Richtung unteren Rand. Die Positionen mOssen 
durchgangig durchgezahlt sein. 


Funktion 


Beschreibt die Funktion der Linie. Foigende Funktionen kfinnen 
unterstOtzt werden: 

ON: DerStrich erscheint auf JederSeite 

OFF: Der Strich erscheint auf keiner Selte 

BS1: Zum Zahlen der Blatt-Sequenz 

BS2: . Zum ZQhien der Blatt-Sequenz 

BS4: . Zum zahlen der Blatt-Sequenz 

EVEN: Bildet eine g'erade Paritat 

ODD: Bildet elne ungerade Paritat 

LAST: wird bel der lelztenBriefseltegesetzt 

NOTLAST: Wird bei alien Selten auBer der letaten Briefseite geselzt. 
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DGR: ' DGR-Funkflon 
DZ: DZ-Funktioh 



Sine Funktion EfrptyPacfelnpert fugt . beispielsweise eine oder 
5 inehrere neue leere Seiten ein. Mdgliche Attribute, sehen wie 
folgt auS: ' 




Attribute 


Funktion 


PageWidth 


Breite der neuen Seite. _ _____ 


PageHelght 


Hfihe der neuen Seite 


PageNo 


Seitennummer des momentanen Dokuments wo die leere(n) 
Seite(n) eingefugt werden soil 


Position 


„ After" oder „Before'\ Gibt an, ob die Selte(n) vor oder nacrY 
PageNo eingefOgt werden sollen 


NumberOfPages 


Anzahle der leeren Seiten, die eingefugt werden sollen. 



10 




Durch eine Funktion Merge konnen verschiedene PDF-Dateien 
zus ammenge f unr t werden: 



Attribute 


Funktion 


Name 


Kann benutzt werden, urn eln Merging zu benennen. 


StartPage 


Gibt an, an welcher Stelle des momentanen Dokuments ein anderes 
Dokurnent hinzugefQgt werden soil. 


EndPage 


Dieses Attribut 1st wlchtig, wenn abwechselnd vom momentanen 
Dokurnent und von anderen Dokumenten Seiten genornmen 
werden. 1 


Step 


0, wenn die neuen Dokurnent komplett in die angegebene Stelle, 
elngefOgt werden sollen, ansonsten werden mit dieser Schrittweite 
abwechselt Seite von dem' aktuellen Dokurnent und dem 
hinzugefOgten Dokumenten benutzt. 


Position 


»After ,f oder "Before". Gibt an, ob die Dokumente vor oder hinter der 
mit Startpage angegebenen Seite eingefOgt werden sollen. _ 


Overlay 


"true" oder "false" 
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Description 



Kann benutzt werden, urn einen Merge-Vorgang genau zu 
beschreiben. 



Innerhalb von Merge werden zweckmafeigerweise die Dokumente 
mit InsertPDF angegeben, die einzufugen sind- Attribute yon 
InaertPDF. k6niien beiepielsweise folgende sein: 




Attribute 


Funktion 


NewStartPage - 


Start-Selte des Bereichs, der von diesem Dokument elngefugt 
werdensoll- " , 


NewEndPage 


End-Seite des Bereichs. der von diesem Dokument elngefugt . 
werdensoll. 


NewStep 


Kann benutzt werden Urn jede x-ste Seite einzufugen. Z. B. 
New$tep= 4i 2 n -> e$ wird jede zweite Seite aus dem Bereich 
elngefugt.. 


Filename 


Name der batel die elngefugt werden soil 


peleteAfterlnsert 


„TRUE" Oder „ FALSE", bestimmt. ob die Datef naoh dem 
Elnfugen geloscht werdeh-sol). 



10 



15 



20 



Eine Funktion Impoai tioning ist zweckroaSig, urn zu bestimmen, 
wie ein Dokument ausgeschossen werden soil. Innerhalb von 
Ixnposxtlorixng k6nnen beliebig viele Seiten beschrieben 
werden. In der Seitenbeschreibung wird festgelegt, welcbe 
Seiten aus dem Original -Dokument auf den neuen Seiten 
positioniert werden. Die Seitenbeschreibung wird vorzugaweiee 
mehrmals durchlau£en,\ wobei jeweils die zu nehmende Original- 
Seite neu berechnet wird- Die Anzahl der Diirchlaufe richtet 
.sifch nach'den .Werten in signature, Increment und .nach der 
Aiizahl cier briginaleeiten, Es wird vorzugsweise so oft 
durchlaufen, wie die Anzahl der Seiten in Signature* Increment 
passt (Aufgerundet) . 



M&gliche Attribute fur Jmpositioning sind folgende; 
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Attribute 


Funktion 


PageWIdth 


Seiteri-Brelte fGr das neue Dokument l - 


PageHeight 


Seiten-Hohe fur das neue Dokument 


Increment . 


>Schrittvyeitef0r.denS6itenzah!er . 


Signature 


Bestimmt die Anzahl der Durchiaufe. Wenn ein Einfachnutzen 
produziert werden soil, muss Signature der Anzahl der Original- 
Selten auf einer neuen Seite seia — 


i 

'Attribute filr A&dPag-e. sind* dabei: . 


Attribute 


Funktion 


StartPage 


Die Original-Seite, die belm ersten Durchlauf posittohtert wlrd 


CouritDlrection 


"positive" oder "negative", bestimmt; ob der bei Increment 
angegebene Werte bel den Durcblaufen jeweils addiert oder 
subtrahlerf wird. 


xPos 


Bestimmt wo in horizontaler 1 Richtung die Original-Seite auf der 
neuen Selte positionleri wird. Abstand in mm vorri llnkea- 
Seltenrand genriessen. 


yPos 


Bestimmt,. wo In vertikaler Richtung die Origingl-Seite auf der 
neuen Seite positioniert wird. Abstand in mm vom unteren 
Seitenrand gemessen. 


Rotation 


„Q il r .,90", „180" Oder ,,270". Bestirpmt die Ausrlchtung der. 
Originai-Selte auf der neuen Seite. 


xScale 


Dienf zur.horizontalen Skalierung. Mit J" bleibt die OriginalgroBe ■ 
erhalten. bei „2" wird die GroBe verdoppelt. 


M i 

yScale 


Dientzur vei^lkalen.Skailerung. Mit „1 u bleibt die. OriginalgroBe 
erhalten. bei „2" wird die Gr6Be verdoppelt. 



10 



Innerhalb der Konf iguration des Druckauf tragerzeugungsmittels 
kann ^uf versciiiadene .Variablen zugegrif fen werden. 33iese 
Variablen konnen verwendet werden, um 'eiyien' Dokuraentnamen und 
verechiedene Texte in neuen Dokumentqn zu er^tellen. Die 
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38 • 

Variablen warden ja nach Function zu Beginn oder wanrend der 
Produktlon gesetzt. ■ 

*Zur lokalen Datenhaltung innerhalb dee erf indungsgemaSen 
Drucksystems iq mit -einem installierten 
Druckauftragerzeugungemittel 15 ist ein Queuefoanager 
yorteilhaft. Er verwaltet fur all© User Jobs und Print Jobs die 
notwendigen Information^, . wie z*B. Status, Dateien und/ oder 
Attribute.' Dazu yerwendet der QueueManager vorzugsweise eine 
hierarchische Datenstruktur. Diese. Datenstruktur legt er bei 1 
jeder Anderung auf einem Speiehermedium wie einer Festplatte 
ab, damit nach einem Neustart des .System* alle Inf ormationen 
noch vorhanden sind. Das Verzeiphnis 1st beispielsweise 
konf igurierbar uber ein Attribut QueueMaji^erPath in einer 
Konf igurations-Datei ' (PSSConf iguration.xml) - In* dem 
Verzeicnnis wird 'vom QueueManager jeweils ein , Verzeicnnis .fur- 
User Jobs und Print Jobs, angelegt, in denen die entsprechenden 
XML^Dateien abgelegt warden. 

20 Im Folgenden ist ein Beispiel fur QueueManager dargestellt. 
•Der aufcerste. Container heifit itnmer QueueJtonager. In diesem 
befiinden sich' zwei Container: Print Jcabs fur alle Print Jobs 
, ' und UBBTJobs fur alle UserJobs. 



15 




25 



30 



35 



40 



QueueManager* 
Print Jobs^{ 
X0000179_l={ . 

PagecountSum=100; . 
. Statuis=Waiting; ' 
LogicalProduct aMF_MAIIiIMG_PDF ; 
CreationDate~28.05.2002; 

CurrentPrinter^4C - IC100 simplex/ Kuvertierung Duisburg/ 

UserJobs={ 
Usertfobl*10000179; ■ 

}, // End of UserJobs * , , 

AvailablePrinter™ { 
4C - IC100 simplex/Kuvertierung Duistourg»{ 

PRINT MODE=SIMPLEX; 

PAGE FORMAT-DIN A4; 

PRINT_COLOR»4C ; " . : ; . 
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TOOTROL^DATA^ALLOWBD^TRUE ; . , . 

ORIENTATIONePORTRAIT ; 
} .// 'End o£4C - IG100 simple^/Kuverfciearung Duisburg 
Merged in one. PDF SIMPLEX={ 
.5 PRINT JVIODE«SIMPLEX; 

PAGE_FORMAT=DIN A4 ; 
CONTROLJJDATA_ALLOWED= TRUE ; 
/ ,ORIEOTATlON«a PORTRAIT ; 
} // End of Merged in one PDF SIMPLEX 
10 } // End ofAvailablePrinter • 

Flys={ 

Plyl«{ . . ■ • 

Status«Waiting; . 
} // End of Plyl ... 
is } // Bnd ofPlya . ' 

} //End ofl0000l79_l 
} // End ofPrinttfobs 
UserJobs={ 
10000179^{- 

2 0 Current Printer=4C - IC100 eiinplex/Kuvertierung Duisburg; 

CreafcionDate=27 . 05 . 2002 ; 
Id=10000179;- 

Iiaa tChangeDafc e=2 9 . 0 5 . 2 0 02 / 
LOgicalProducttoMF_MAILIWG_PDF; 
25 PageCoimt:S-um»100 ; 

Downloaded=TRUE ; 
PageCounfcLetteral ; 
Status^Waiting,- 
AddressCount«100 ; 
30 Percentages 0; 

DownloadedDateF*28 . 05 . 2002 ; 
OobAttributes=>{ 
PARTNER_D0WNLOAD_TIME STAMP- 2 7 ; . 0 5 2 0 0.2 1^-28:46; 
PRINT_COIiOR=4 C ; 
35 PRINTJMODE-SIMPLEX; 

POSTAGE_INF01iSTTER_STANBARDBRlEF==100 ; 
CURRENT_PARTNER ID»5000000; 
POSTAGE ±NFOPOST_STANDARDBRIEF=0 # - 
PROJECT~IDo5160036; 
4 0 PARTMER~COMPIiETION_PERCENTAGE= 10; 

PORTO_START_DATE=>27 . 05 - 2002 14 : 02 : 406 ; 
PARTNERJLAST UPDATE=27 * 05 .'2002 16:28:46; 
RANGE_0F_PAGES»l-3 / . . 

CnJRRENT_PARTNER_INSTANCE»OLS ; 
45 POSTAGE^INFOIiETTER_ADD_STANDARDBRIEF»0 ; 

" TOTALJKUMBER_OF_PAGES=100/ 
!NUMBER_OF_PAGES«l 
INITIAL JNXMBER_OF_PIBCES=10P ; 
GROSS^WEIGHT=97l665S; 
50 ORI ENTATI ON=PORTRAX T ; ' 

' POSTAGE STANDARD_STANDARDBRIEF=0; 
• POSTAGE~INFOPOST__ADD_STAND2yU)BRIEF«0; 
PAGE_FORMAT=DIN A4; 
} // End of JobAttributes 
55 Print Jobs«{ " 

PrintJobl«i 000 0 17 9_1 ; 
} // End of PrintJobs • 
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IS 



. AvailablePrinter={ 

4C - IC100 Bimplex/Kuvertierung Ouisburg={ 
' PRINT_MODE«S IMPLEX ; 

PAG2_FORMAT«DIN A4/ 

PRINT_COL0R==4 C ; 

CONTROL_DATA_AIiliOWED»TRUE; - 

ORIENTATION«PORTRAIT; 
} 7/ End of 4C - IC1Q0 siinplex/Kuvertierung Duiaburg 
Merged in one PDF SIMPLEX={ 

PRINT MODE=SIMPLEX; * 

PAGeJFoRMAT-DIN A4,- 

CONTROL DATA_ALliOWED«.TRUE; 

ORIENTAT JON=»PORTRAIT ; . 

. . } // End ofMerged in one PDF SIMPLEX 

} // End ofAvailablePrinter 
} // End ofl0000179 
} // End of User Jobs 
) // End ofQueueManager' 
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Eine beispielhafte Datenstruktux, die der QueueManagar fur 
einen Userijob anlegfc, ist der folgenden Tabelle zu entnehmen: 



UserJoblD 




CurrentPrinter= 
CreationDate= 
td^ 

LastChangeDate= 

LogicalProduct= 

PageCo0ntSum= 

Dbwnloaded= 

PageCountLettep* 

Status= 

AddressCount= 
Percentage= 



JobAttributes 


PrintJobs 


AvalloblePrinter 


JobAttributel = 


PrintJobl = 


Printer! 


... |PrinterN 
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Attribute T= 




Attributed 


. {alle UserJob 


.{alle PrintJobs) 








Attribute) 




4 








PrintJobN= ' 


Attributed 




AttributeN 


JobAttributeN= 













.Bei der Synchronisation mifc derti SOAP-Server warden , die 
s Attribute von nauen User Jobs, erf ragt. Mi.t diesen Attributen 
legt der QueueManager ei'nen neuen UserJob an. Dabei wird 
beispielsweise wie folgt vorgegangen: ■ 

i ' ' 

l 

- Erzeugen des neuen; userJob-Containers 
16 - .Attribut ID wird mit UeerJoblD gesetzt 

- Attribut Status ,wird au£ REABY_FOR_DOVMLOAD gesetzt , 

- Attribut Percentage, wird auf 0 gesetzt .. 

- LofficalProduict wird auf den entsprechenden Wert gesetzt 

- ' Downloaded wird auf FALSE gesetzt. 

15 - LastChan&eDate wird auf • die aktuelXe Ubrzeit gesetzt 

- Der Container u^erAttriJbune wird hinzugefftgt 

- Ein leerer PrintJobs -Container wird .hinzugefdgt 

' AddressCounfc wird aus den UserJob -Infprmationen gesetzt 

- CreationDate wird aus den Job- Infprmationen gesetzt 

20 !- PageCouhfcLetfcer wird aus t den Job-lnforraationen gesetzt 
. - PageCduntSum wird aus den Job-.Inf ormationen gesetzt 

- Der Container AvailaJblePrinter wird; hinzugaf ugt . 



25 • Mftgliche virtuelle Drucker ergeben eich aue der Kdnf igurafcion 
in einar PSSConf iguration. Bs werden alle Drucker .eingefugt, 
deren print JoJbConditions keine Attribute des User Jobs 
ausschl'ieSen. Die PjrintiTobCondltlons werden Kr 'jeden Drucker 
in der Struktur gespeicbert . , Wird im weiteren Verlauf aus dem 

30 UserJob ein oder mehrere PrintJobs erzeugt, werden die 
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entsprechenden Uad&oblDa im Container PrintJobs einge.tragen.. 
Bei .jeder Anderung, beispielsweise bei status.anderungen, wird 
das Atfcribut iastChangreOate vom QueueManager neu gesetzt. 
Wird der User Job heruntergeladan, . so wird Downloadedbate 
gesetzt 'und die heruntexgeladene XML-Datei im TJsar-Job- . 
Verzeichnis abgelegt. 

. Bine beispielhafte Datenstruktux, die der pueueManager fOr 
einen- PrintJob anlegt, ist der. folgenden Tabeile zu 
. enfcnehmen :' 



PrintJoblD 





PageCountSum- 
Status- 

LogicalProduct= 
CreatioriDafe== 
CurrentPrtnter= 
' StartAddress= . 



UserJobs / 


AvailablePrinter 


Plys 


UserJob 1 = 1 

. (UserJob In diesem 
PrintJob) 

• 

U$erJobN= 


Printer! . 


■ * » 


PrlnterN 


Plyl 




PlyN 


Attribute! » 
AtfributeN 




Attribute! = 
AttributeN 


Status= 




Status- 



is Wird aus einem oder mshreren .Usertfobs ein -PrintJob angelegt, 
" v erstellt der QueueManager dan 'entsprechenden Print job- 
Container, Dabei wird beispielsweise wie fblgt vorgegangan: 

r Atis den UserJob XML«Dateien wird eine Oder mehrere 
20 ' PrintJob XML-Datei erstellt 
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' - Der Print Job- Container wird angel egt 

, -* Status wird auf WAITING gesetzt 

' - LocricalProduct, wird gesetzt, wobei der Wert 'durch 

t ■ 
. den/die UserJob(s) vorgegeben wird 

5 ' • - .Der UserJob-Container wird angelegt und all© User Jobs, 

aus denen dieser Print Job besteht,. werden eingetragen 

- Der AvailablePrinter-Container wird yom UserJob kopiert . 
urid eingef -Qgt _ ! . * 

- ' Wenn aus einem User Job mehrere Print Job© erstellt warden 
10 sollen, -weirden StartAddrese und EndAddreae gesetzt (Der 

Adressbereich fur diesen PrintJob) f • 
— ' PageCouritSum wird gesetzt (Anzahl • aller Druckseiten in 
diesem Print Job ) 

- Curr-entPrinfckr wird auf den gewablten Druckeir gesetzt 
•15, Es.wird ermittelt, auf wie viele Plys der Print Job 

# aufzuteilen. ist (Ergibt sich aus' zu druckenden Brief en 
- und A ttr:L:b uten Addre&aesPerPly des Druakers in der 
Konf iguration) 

; ■ 7 Der Plys-Containef Wird entsprechend erstellt und alle 
20 Plys auf WAITING* gesetzt ' ' \ . 

- GreationDate wird auf die momentane Uhrzeit gesetzt . 



Bei jleder weiteren Anderung des Print Job- Status .warden von 
25 'den dazugehorigen UserJobs .LastChan&eDate und, Percentage 
aktualisiert . 

Beim Erzeugen . eines Print Jobs wird aus den UserJob .XML- 
Dateien eine neue Print Job XML-Datei erstellt. Diese 
Funktion wird beispielsweise von einer Klasee RecreiateXML 
30 ubernomrnen. Die Datei User Jobr XML enthalt beispielsweise 
User Job-Attribute, t Company- Da ten, Item-Daten und UserJob- 
■ Files, Die User Job Files sind in einem besonders 

bevprzugten Ausfuhrungsbeispiel der Erfindung Base64- 
kodiert. Bei Base64 kandelt es sich urn eine Codierung, die 
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durch-.das Programm MIMENCODE im MIME -Standard benutzt 
wird, urn bin&re Daten in ein iVSCII -Subset, umzuwandeln. 



10 




15 



Die Klasse RecreateXML fasst alle UserJobs in. einem 
JOBTRANSFER- ENVELOPE zusammen. Die User Job-Attribute, • 
Company-Daten und Item- Daten von jedetn User Job werden 
unver&ndert ^ernommen; Die Dateien mit den Print- 
Instruktionen und den variablen Daten* werden von RecjreateXML 
ver&ndert. Die restlichen Dateien werden tibernommen. 

Wird eiri User Job in mehrere Print Jobs aufget'eilt, werden die 
variablen Daten auf satze auf geteilt . Jeder Print Job erh3.lt 
einen dieser S&tze* 

Die Print -Instruktionen der User Jobs konnen beispielsweise in 
folgendem Format sein: * • 




20 



25 



30 



35 



40 



<?xml version^l.O" encodirig= u ISO-8859-l n ?> 

<USER30B_HAtMDLINGJNSTRUCnONS Version = n 2 +X n > 
<DATA^FIELD_DESCFaPTION> 

<DATA_FIELD NAME= w F±rmajL n ABBREV«Voo" /> 
<DATAJ=IELD NAME~ tt Atojtareflta" ABBREV*"d01 n /> 
<DATAJ=IELD NAME^'toMd*" ABBREV= n d0Sl u />. 
<DATA_FIELD NAME= , *vomaxne n ABBREV=* n d03 n /> 
<DATA^FIELD NAME:* ^ Naalmame ,l ABBREV^^^" /> 
<0ATA_FIELQ NAME= u SfcIrasee ,, ABBREV="d05 u /> 
<DATA_FIELD NAME= w 3?i,2 lr . ABBREV="d06 w /> 
<DATA_FIELD NAME^'o^t" ABBREV^dOv" /> 

</data_fieldLdescription> 

<f=ORMATTER u _INSTRUCnONS VersIon= n i- o"> 
• <CONTENT_ASSIGNMENT 
D ATA_lFIELD_N AM E = "Fixina^l" /> 
1 <CONTENT.ASSIGNMENT 
DATA__FIELD_NAME= l, Adr Anrede" /> . 

<CONTENT ^ASSIGNMENT 
DATA_FIELD_NAME= n Vornajae n /> 

<coKrrernLASSiGNMENT 

DATA^FIELD_N AM E= "lsrachname 1 ' /> 

<CONTENT_ASSIGNMENT 
DATA_FIELD_NAME= ,, Straeee n /> 

<CONTENT_ASSIGNMElSTT CONTCNT_ID<= n FpstalCoda n DATA_FIELD^NAME= n t»i,z 

/> 

< CONTENT-ASSIGNMENT CQNTENT_ID="city'! DATA^PIELD_NAME="Orfc" /> ; ' 



CONTENT _ID="Ccnx^>axiyl-aLneX n 
CONTENT_ID= n Title w 
CONTENT_ID« n FirstHame n 
. CONTENT-ID= n X»astKTame n 
CONTENTED = "S traatwi thMo w 
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<EMPTYL2NEBEFORECTTY OBUGATORY="FALSB B /> 
<SALUTATIONLINE LINESUFFDC=% " PATTERN _ID=" 6 n /> 
</FORMATTERJMSTRUCTIONS> 
<PRINTING_INSTRUCTIONS> 

< PRINTFIELD_M APPING > 

<PRINTFIELD NAME-°M»Bl n SPACETRIM MING« M FALSB tt > . . 
<FORMATTER_FIELD SEQ="l" NAME="Lette*HeadjRow_jt n /> 
</PRINTRELD> 

<PRINTFIELD NAME» w LXiaE2" SPACETRIMMING= "false" > 
<FORMATTER u _RELD SEQ= M 1 D NAME= n Lett6rHead_Row_2 u /> 
</PRINTFIELD> 

<PRINTRELD NAM E= "LXNB3 " SPACETRIMMING= "FALSE" > , 
<FORMATTER_RE!_D SEQ="1 ? NAME="LetfcerHeadJ&ow.3 n /> 
</PRINTFIELD> 

<PRINTFIELD NAME^'MH^ SPACETRIM MI NG= "FALSE" > 
<FORMATTERJ=IELP SEQ»"l" NAME«"Letfce:i^ead_Row_4 n /> 
.< /PRINTFIELD > 

<PRINTFIELD NAM E= "lines n SPACETRIM MING= "false" > : , 
<FORMATTERJ=IELD SEQ= B l" NAME=' , L e tterHead_a OW _5 ,, /> 
</PRINTRELD> v 

< PRINTFIELD NAME= M LiNB6 n SPACETRIM MING ="false m > 
<FORMATTER^.FIELD SEQs"!^ NAME^^Btfcer^ea^Row^" /> 
</PRINTFIELD> 

< PRINTFIELD NAME="LINE7" SPACETRIMMING= "FALSE" > 
<FORMATTER w FIELD -SEQ«"x tt NAME^Lafcfc^eac^Rowjr" /> ■ 
</PRINTRELD> 
' < PRINTFIELD NAM E^AB SENDER" SPACETRIM MING = "FAME" > 
<STATIC_FIELD SEQ= H X" VALUE= r, MHON wirtsehaffcsinfioxmafcik 
- Daimlerweg 39-41 - 48X63 Munstar" /> 
</PRINTFIELD> 

< PRINTFIELD NAME-"anrbde" SPACETRIMMING-"fai.se"> 

<FORMATTER^RELD SEQ=' , x" NAME«"SalutafcionL±ne n /> 

</PRINTFIELD> 

</PRII\rTFIELD_MAPPING> 

<PRINTFIELD_PdSrnONS> 

< POSITION POSX**"25" POSY="230" FO NT= "HELVETICA" 
COLOR= n BIiACK n PAGEFROM=* !I i" PAGETO="l n NAME="line1" /> 

<POSmON POSX="25" POSY=* n 246 n FO NT= "HELVETICA" 
COLOR= n BLACK" PAGEFROM="l" PAGETO="x" NAM E= "LXNE2 n /> 

<POsmoN pasx^s" posY= n 242" font* 3 "helvetica* 1 

COLOR*"black" PAGEFROM«"l" PAGETO^"!" NAME= n iiH3B3° /> 

<PbSinON POSX«"25°' POSY= n 23r8° FONT="HELVETICA" 

COLORfe n BLACK w PAGEFR0M«"1" PAGETO^ M X M NAME="limE4" /> 

<POSITION P0SX="25" P0SY= n 234 n F0NT= "HELVETICA" 

COLOR= n BtACK n PAGEFROM= n X tt PAGETO="l" NAME="LXNE5" /> 

<POSITION . P0SX=="25 tt POSY="230 ,> FO NT= "HELVETICA" 

CO LOR = "black" PAGEFROM « n x n PAGETO= n l" NAME^ W LXNE6" /> 

< POSITION POSX=3 M 25" POSY="226" FONT= "HELVETICA" 
COLOR="black 0 PAGEFROM= w l B PAGETO= n l n NAME="LX*IE7" /> 

<POSrndN POSX="25 n POSY="i89 n FONT« "helvetica" 
CO LO R» "black" PAGEFROM ="i° PAGETO^ m x" NAME="AttRSDB w /> 



GMBH & Co. KG 



FONTSIZE="X0"- 

FONT5IZE= tt X0" 

FONTSI2E= ,, X0 tl 

FONT5IZE= n l0 n 

FONTSIZE="xo" 

FONTSIZE^XO" 

FONTSIZE="10 M 

FONTSI2E="10 U 
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<:POSITION POSX-'^a"" POSY="260 n FOfNTT^ "HELVETICA" 
COLOR== n BX»ACZ" PAGEFROM«°i n PAGETO= n l w NAME= n A3SENDER" /> 
</PRINTFIELD_POSrnONS> 
</PRir4TING_ i INSTRUC710NS> 

</USEiUQB^HANDUMGlINSTRUCnONS> 



F0NT5IZE= n fi n 



RecreateXML behutzt vorzugsweise einen" Adressf oirnatierer, urn" 
10 daraus Druckanweistmgen zu generieren, die von dem PDF-Kernel 
vers,tanden werden. In dem PrintJob-Piie sehen .die ■ 
. Prinfcinstruktionen ftir die obeix angegebene Datei 
. beispielsweise wie folgt aus: 





15 



20 



25 



30 



35 



<VarJabfeData StartPage= M l" step="i u EndPage="i u > 

. <ADDTEXT RECORD^lihei" yPds= M 25o w Co!6r= n BLACK" FontSlze«= n io n ^Pos^s" 

Font» "HELVETICA" /> 

<:ADDTEXT REC0RD=*LnsE2 n yPos= n 246 n Colors "black" FontSize= n 10" xPos="25 n 

Font= "HELVETICA" /> 

. <ADDTEXT REGORD^lznes 1 ' yPos» n 242" Color^ n BLACK" FontSizes^io" xPos« M 2S" 
Fpnt= "helvetica" ./> 

<ADDTEXT RECO RD = "LINE4 " yPos^SB" Color** "black" FontSlze^iO" xPos-^s"- 

F0flt=* "HELVETICA" /> 

<ADDTEXT RECO RD= "limes" yPos- ff 234" Cfclor~ "black" FontSize= n io n xPds="25 n 
Font= "helvetica" /> 

<ADDTEXT * RECORD* 3 "lutes" yPos="230 n Color="BLACK" FQntS!ze=5 ,< l0 , ' xPos= n 25" 

Font^'HELVETlCA" /> 

■*ADDTEXT REC0RD= n LXNE7 n yPos="226 H Color="BiACK n FontSize^'xo" xPos«"25 H 

F0nt= "HELVETICA" /> 

<ADDTEXT RECORD = "anrede" yPos=* 0 l89 n Colors "blagx" FontSize="lo w 

XPOSa^S" Font= "HELVETICA" /> 

<ADDTEXT RECORD == "absendbk" yPosK"260" Color= "black" FontSUe="e" 

XPOS= n 25 w FO nt= "HELVETICA" /> 

</VariableData> ' 



In der UserJob XML-Datei sehen die variablen Dafcen 
beispielsweise wie folgt. aus : . ' 



40 



<USERJOB_VARIABLE_DATA> 

< RECORD SORT_ID= n 5" 7YPE="i" SEQ«"5?> 
<d07>Ort</d07> 

<dQ6>Postieitzahl</d06> 
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<d05>System</d05> 
<dO4>Nachname</d04> 
<d03>Vorname</d03> i . 
<d02>Herr<:/d02> 

<d01>Herrri Vdrname Nachname</d01> 
, <d00>Unternefrmen</d00> 

</RECORD> 



</USER3QB_.VARIABLE_DATA> 



15 




20 



25 



30 



Unter Verwendung der. Zuordnung in der Print- Jristruct-Datei, 
generiert RecreateXML daraus Folgendes : 



<THE_DATA> . 
< RECORD S0RT_ID= n 5" SEQ= n S n > 

<LINE4>Postle!tzahl Ort</LINE4> ; 

v <LINE3>System</LINE3> 

<LJNE2>Herrn Vorname Nachname</QNE2> 

<UNEl>Unternehmen</LINE}> 
V <ABSENDER>Absender</ABSENDER> 

<LENE7./> ' 

<ANREDE>Sehr geehrter Herr Vornajtien Nachname,</ANREDE> 

' <UNE6 /> 
<UNE5 /> 
</RECORD> ... 
</TH E_P ATA> . _ : : — - m 



Dadurch scehen bei der Personalisierung wahrend der 
Produktion die Eaten in der Form zur Verfugung, wie sie der 
PDFr Kernel direkt verwenden kann. 

Der QueueManager verwaltet f^r alle User Jobs, PrintOobs unci 
Plys den Status;. . Der QueueManager wird Qber statusanderungen 
von einem Datenmodell einer Oberf lSche. benachrichtigt . Dabei 
konnen beispielsweise folgende Status auf tret en:' 



Status 


Anzeige in der Oberflache 


Interventlorijtequlred 


Bngriff notwendig 


Not_Produceable 


Produktion nlcht mogllch 
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Waiting 


Wartend 


Downloaded 


•Heruntergeladen . 


Failed. 


Produktlon fehl^eschlagen 


Reqdy_For_Download . 


nerunTeriauDur 


Cancelled 


Cancelled * 


Preprocessing 


In Pre-ProdukHon 


Preprocessed 


Pre-Produziert. 


Printed 


Gedruckt 


Delivered ' ) 


Ausgellefert 



• Es liat sich ferner ala- zweckm&£ig erwiesen, dass der 
5 QueueManager bei Statusanderungen von UserJobs und PrintJobs 
fur die User Jobs ein Attribut Percentage setzfc. Dieses- 

' . . Attribut gibt die- Fertigsteliung dee UserJobs in Prozent an. 

• .« * i 

Bei der Synchronisation rait dem. Server 20 wlrd .f tlr jeden 
User Job * dieser Wert ubeannittelt . Die Status von User Job und 
xo Print Job in Verbinduncf mit dem- Prozentanteil der 

Fertigsteliung sind in folgender Tabelle dargestellt: 




j 
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UserJob Status 


Status der zugehorigen 
Print Jobs 


Prozent der Fertigstellung 


Interventlon^Required 


- 


10 


Not_Produceabie 




0 


Waiting 1 


Watting 


10 


UOWnlOugcu 






rulieu 






Readv For Download 


• 


0 


Canceled 




Letzfer Wert yor 
Stornierung 


Preprocessing 


Preprocessing 


10 • 


Preprocessed 


Preprocessed ' 


10 


Preprocessed ^ 


Preprocessed / Printed 


10-95 abhdtngig von der ' 
Anzahl der fertigen 
Print Jobs ■ 


Printed • ■ 


Printed 


95 


Delivered 


Delivered 


100 



10 




Besonders vorteilhaft ist es, wenn Benutzer d£s 1 
erf indungsgemafien Driickauf tragerzeugungsmittels 15 innerhalb 
eines Drucksystems 10 die Produktion. uber eine 
Benutzeroberf lSche tiberblicken und steuem. konnen. Die 
Oberfl&che kann beis'pielsweise unter Verwendung von Java 
Swing implement iert werden. Die Daten fur die Oberflache 
werden dabei beispielsweise von einer klasse DataModel 
(Datenmodell) verwaltet, weXche zu Ermittlung von Werten den* 
QueueManager befragt. , . 



15 Vorteilhaft ist femer, dass sich ein Benutzer uber ein Menu 
am SOAP -Server anmelden, abmelden und das ' Programm beenden 
kann. Dieae Funktionen werden vorzugsweise in einer Toolbar- 
Leiste verfugbar gemacht. Beim Anraelden kanin beispielsweise 
eine Dialog-Box gedffnet werden/ in der Username und Passwort 

20. einzugeben sind. Mit diesen Angaben versucht das System/ sich 
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fiber sine Methode authe^ticateUser vom ServerProxy am SOAP- 
Server anzumelden. Gelingt die Anmeldung, warden die 
Benutzerinformationen im Datenmodell geapeiohert. Dieee 
Benutzerinformationen werden bei weiterer Kommunikation mit. 
s dem Server verwendet . Bei einem Fehler erscheint 

zweckmaSigerweise ein Dialog mit einer Fehlermeldung. 

Vorteilhaffc ist es dabei, eine Funktion w Abmelden n zu 
■ implementieren, die Benutaerinformation aus dem Datenmodell. 

io ldsclit,- so dass keine Kortffttunikatibn ohne' exneute Anmeldung 
mit dem Server mehr moglich ist. Bine weitere Funktion 
„Abmelden und Beenden" prftft beispielsweise, ob nocii 
Prpdukt ions -Threads .lauf en. Falls noch Threads vorhanden 
sind, erfolgt eine weitere Abfrage, ob das Programm beendet 

is werden soil; Das Programm wird beispielswe.ise mit 
System- exit (0) beendet. 

uber eine Combo 1 - Box k&nnen beispielsweise drei verschiedene 
Sichten auf die User Jobs* erstellt werden. Fur alle Sichten 

20 gibt es in der Haupt -Frame Klasse (FrmApplikation) innere 
Modell-Klassen. ' Das Hauptf rame . ihitialisiert mehrere 
ChangeL.istener, die bei einer Anderung der UserJob-Selektion 
und einer User Job -Status -Ande rung die mSglichen Aktibnen 
setzen. Die mdglichen Aktionen werden vom Datenmodell 

25 erfragt. Das Datenmodell leitet die. mdglichen Aktionen von 

dem Status der selektierten User Jobs, den es vom QueueWanager 
erfragt , ab. 

Ober das User Job Meml kSnnen User Jobs heruntergeladen, zu 
3 ( o Print Jobs umgewandelt, storniert, auf nicht produzierbar 
gesetzt, zurftckgesetzt und mit einem wizard produziert 
werden. Alle Aktionen kftnnen auch -Qber eine Toolbar-Leiate 
ausgel6st werden. Die moglichen Aktionen hangen von dem 
Status der selektierten User Jobs ab. 

35 




AXG3 Nr: 191927 von NVS:FAXG3.I0.0202/02414007121 an NVS:PRINTER.0101/LEXMARK2450 (Seite 51 von 72) 
atum 19.11.02 15:35 - Status: Server MRSDPAM02 (MRS 4.00) ubernahm Sendeauftrag 
etreff: 72 Seite(n) empfangen 



19/11 2002 DI 18:52 FAX 2414007121 
AC DPA-5228 PDE 



TOD OUOlAIUU/l iUUU 



51 



Die Zuordnungen. zwischen Uaer Job- Status und moglicher • Aktion 
sind in folgender Tabelle dargestellt: 




Status derselektierten 
UserJobs 


Mogliche Aktionen 


Heruhteriadbar 


Herunterladen, Prqduktfons-Wizard 






Heruntergeiaden . 


Neuen PrfntJob anlegen (Falls alle selektierten UserJob 
zu einem PrfntJob zusamrnengefasst werden dGrfen), 
Stomieren, Produktionswizard 


Wartend 1 




Pre-Produziert 




Gedruckt 




Ausgellefert 




Elngriff notwendig 


UserJob nicht produzierbar 


Produktion 
fehlgeschlagen . 


• r 1 


Canceled * 


ZurOcksetzen } . . 



Die Auswirkungen . der User Job-Aktionen sind in der f olgenden 
Tabelle dargestellt: 



Aktion 



Auswirkung 




Herunterladen . 


Die selektierten UserJobs werden In einem etgenen Thread 
durch Aufruf der exportUserJob Methods vom 
PartnerServerProxy heruntergeiaden. Der QueueManager 
wird benachrichtigt, dass die UserJobs heruntergeladen 
sind. 


Neuen PrintJob 
anlegen 


Aus den selektlerfen UserJobs wird ein oder mehrere 
PrintJob erstellt Dabei entsteh'en neue XML-Datelen, in 
denen'die UserJob-Files dekodiert sind .und mit der Klass© 
RecreateXML in ein Vieues vbm PDF-Kernel lesbares XML- 
Format gewandelt werden. Danach wird der 
QueueManager benachrichtigt aus welchen UserJobs 
weiche PrintJobs wurden.. 


UserJob nicht 
produaertoar * 


Es wird die Art des Fehlers und ein Kornmentar abgefragt. 
Der QueueManager wird benachrichtigt. 



AXG3 Nr: 191927 von NVS:FAXG3.i0.0202/02414007121 an NVS:PR|NTER.0101/LEXMARK2450 (Seite 52 von 72) 
>atum 19.11.02 15:35 - Status: Server MRSDPAM02 (MRS 4.00) ubernahm Sendeauftrag 
etreff: 72 Seite(n) empfangen 



,18/il 2002 DI 16:53 FAX 2414007121 . 

AC DPA 5228 PDE 



52 



Produktionsw&ard 


Der Wizard wlrd gestartet; der alle selektierten UserJobs 
herunterlfldt, Jeweils einen Print Job erzeugt und dteson 
produziert;/ ' 


stornieren 


Der QueueManager wird benachrichtigt, dass die 
selektierten UserJobs stornlert werden sollen, : 




10 



Besonders vorteilliaf t 1st f erner - der Einsatz • eines 1 . 
Produktioriswizards. Der Productions -Wizard gruppiart alle 
selektierten UserJobs nach Produkten. Falls kein User Job 
selektiert wurde; warden alle UserJobs benutzt. Zu der 
Gruppierung. benutzt • der- Wizard beispielsweise* die Attribute 
PRINT_MODEs, PRZNTjCQLOR und PJRINT^FORMAT 9 Die folgende 
Tabelle stellt die. wizard- Produkte .und ihre Atrr'ibute dar: 



Wizard-Produkt 


PRINTMODE 


PRINT__COLOR 


PRINT_FORAAAT 


farbtg, simplex ; 


SIMPLEX .' 


4C • 


DIN A4 


farblg, duplex 


DUPLEX 


4C . 


DINA4 • 


s/w , simplex 


SIMPLEX 


few 


DINA4 


s/w , duplex 


DUPLEX 


BW 


DIN A4. 


Funcard 






DIN A6 



15 




20 



Die Sicht auf die Print Jobs kann ebenfalis iiber eine ComboBox 
ausw&hlbar geraacht werden. Die sicht en und das ■ Akt ions - 
Handling, sind wie pel den UserJobs implement! ert , mit dem 
Unterschied, . dass die Werte filr' Print Jobs vqm QueueManager 
erf ragt werden. 



25 



Die tnogliohen Aktioneii liangen von dem Status der selektierten 
Print Jobs ab. In der folgendexl Tabelle.. xsfc die Zuordnung 
zwischen PrintLob-statuB und mSglicber Aktion dairgestellt : ■ 
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Status der selektierten 


Mogliche Aktionen 


PrintJobs 




Wartehd . 


Prociuzierdn,AuflSsen, Drucker wechseln 


Pre-Produziert 


Druckwiederhoiung; AuflQsen, ZurOcksetzen 


Gedruckt 


Druckwiederholung, Ausliefern, Aufl6sen 


Eingriff notwendig 


Produzleren, Aufloseri ZurOcksetzen 



Die folgende .Tabelle zeigt die .AuBwirlcungen der PrintJOb- 
5 Aktionen: , ■> 




Aktion 


Auswfrkung 


Produzleren 


Der PDF-Kernel wird angewiesen, den PrlntJob zu 
produzieren, Der QueueManager wird Ober das Ergebnls 
der Produktion infomniert. . 


Druckwiederholung . 

* . 


Der PDF-Kernel wlrd pngewiesfcn. einen TeiJ des PrintJobs zu 
produiereri- Der QueueManager wlrd Ober das ftgebnis 
der Produktion Informlert. 


Ausliefern 


Der QueueManager wlrd benachrichtigt. dass der PrintJob 
ausgeliefert wurde. 


Druckerfiindetn. 


Der QueueManager wlrd benachrichtigt, den Drucker zu 
setzen. B werdert nur Drucker zur Auswahl angezeigt, auf 
denen der PrintJob produzierbar 1st. Die Drucker werden 
vom QueueManager abgefragt 


ZurOcksetzen 


Der QueueManager wird benachrichtigt, den PrintJob 
zurOckzusetzen. 




lo Bine vorteilhafte AusfOhrungsf orm der : Erf indung ist ferner, 
dass ein Benutzer uber ein Server-Menii synchronisieren und 
den loksiien Cache zurucksetzen kann. 



Wird' eirie Synchronisation durahgefCthrt , .sendet daa 
is Druckauf tragerzeugungsmittel zunkchst alls Status und den 

Grad der Feftigstellung in Prozent der lokaHen User Jobs unter 
Verwendung des ServerPrqxy an den Server -Hat ein User Job den- 
Status CANCELED, FAILED oder DELIVERED, wird der QueueManager 
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anschlieSend angewiesen, dieee Jobs lokal zu ldschen.* Nach . 
der -Status-Ubermittlung fragt das 

Druckauf tragerzeugungsmittel alls herunterladbaren 
„ Exportable" User Jobs ab. Falls ein herunterladbarer User Job ' 
• s noch nicht lokal, vorhanden' ist, wird der QueueManager 

beauftragt, diesen anzulegen. Danach warden die Attribute von 
diesem neuen User Job vom Server erf ragt und dem QueueManager 
mitgeteilt. Falls bei der Abfrage der Attribute ein Fehler. 
.auftritt, wird der QueufeManager beauftragt/ dieBen User Job 
ID auf NOTPRODUCEABLE zu setzen. 

... , Im.nichsten Schritt fragt das Druckauf tragerzeugungsmittel 

• die Listener bereite heruntergeladenen User Jobs vom S.OAP- . 
Server ab. Frills User Jobs, die bereits heruntergeladen ■ 
is wurden, nicht mehr lokal vorhanden sind, werden die. User Jobs 
uber den QueueManager neu angelegt und heruntergeladen. Dies 
kahn beispielsweise auftreten; we,nn die- lokalen Dateien des 
QueueManagers gelpscht werden. Palls es lokale User Jobs gibfc, 
die nicht in der Liste der heanintergeladenen User Jobs sind, 
20 warden diese UserJobs lokal geloscht* 

Wenri der lokale Cache zurtickgesetzt wird, werden zun&chst 
alle Print Jobs aufgelost. Danach werden alle Dateien, die der 
' QueueManager verwaltet, geloscht „ Nach dem iiun folgenden 
25 Itfeustart deB QueueManager© wird eine Synchronisation 

durchgeffthrt, bei der allerdings das Ubermitteln der Status 
an den SOAP-Server enfcf&llt. 

in einem besonders bevorzugten Ausfuhrungsbeispiel der . 
* 3o Erf indung werden alle Fehler, die innerhalb des 

Druckauftragerzeugungsmitteis auftreteri/ dem Benutzer in 
einem Dialog ahgezeigt. Aufeerdem werden die Fehler mit Datum 
voraugsweise in einer Log-Datei gespeiehert. Die Datei heist 
beispielsweise Error. log und liegt in einem Verzeichnis, das 
35 in der Konf iguration unter erroxpath angegeben ist. ■ ' ■ 
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Vorzugsweise werdeh alle ftir die Produktion verwendeten 
Informationen in einem JobEnvironment gespeichert . Dabei 
5 werden zuerst alle im Print Job enthaltenen User Jobs in 
. Datenobjekten einer Klasse UserJobData, gespeichert. Diese 
Datenobjekte bieten einen Zugriff auf alle far die Produktion 
wichtigen UBerJob-Daten. Damit die gesamte Anzahl bekannt 
ist, wifd von alien User Jobs die Anzahl der Adressen, Seiten 
io und Blatter addiert urid gespeichert. • 

JobEnvironment analysiert, wie vieie Brief e' filr ein 
jeweiligse Inf opostkriterium Infobrief , Infopost oder 
Standard vorgesehen sind. Aus jeder Adresse wird ein 
is Datenobjekt einer Klasse Letter erzeugt . Fdr den weiteren 
Produktionsverlauf stellt JobEnvironment Methoden zur 
Verfugung, " urn bestimmte Information tiber die User Job 
abzufragen. • . 

20 Die klasse Letter enthalt Information fur einen Brief. Dazu 
gehorfen beispielsweise -Personalisierungsinf ormationen, Anzahl 



25 




der Brief seiten, das Inf opostkriterium, UserJoblD, und die 
Posit ion innerhalb des User Jobs. Das JobEnvironment verwa] 
eine List© mit Letter-Objekten fur alle Brief e. 



Vorzugsweise enthSlt ein Objekt der Klasse UserJobData alle 
• Daten eines User Jobs. Dazu gehoren alle User Job-Attribute, 
Porto- , . Freis- und Firmeninformationen. Das JobEnvironment 
besitzt eine Liste User Jobs mit alien UserJobData-Objekten 
30 des Jobs. Die Klasse UserJobData bietet Methoden> urn auf die 
UserJob -Informationen zuzugreifen. 

zur Verwaltung der PDF-Seiteninhalte ist die Verwendung einer 
Klasse Pagecontent zweckmaSig. . Objekte dieser Klasse 
35 beschreiben fttr eine Seite, welche Briefe sich auf der Seite 
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auf welcher Position befinden, KB ist moglich, dass sich auf 
einer Seite naeh dem Durchfuhren von Impositioning mehrere 
Brief e befinden. 

VorzUgsweise werden mit Hilfe einer Hashtabelle 
bocumentsContent die seiteninhalte fur jede PDF -Datei . 
verwaltet. Darin werden fur alle PDF-Dokument die Dateinamen 
.und .eine Lists von FageContent abgelagt. Erstellt warden" 
diese vorzugsweise von einem PDFLayer.' Die Informationen 
dienen fur eine ONIR und SDL-Erste.llung und zur Erstellung 
einer PDF-Vorlage mit statischem . Inhalt . 

'• Es ist ferner vorteilhaft, fur eine vorhandene PDF-Datei mit 
Personalisierungsdaten an einer beliebigen Stelle eine PDF- 
is Vorlage mit den statischen Inhalten zu erzeugen. Dabei wird 
untersucht, welche Vorlkgenseiten bendtigt werden. In- 
xrariaWeroTeinplateftfatcJi wird fastgehalten, welche 
personalisierte Seite zu einer statischen Seite gehdrt.Die 
' information wird aventuell bei einer spateren Erzeugung eines 
20 Book-Tickets benStigt. In varToT&nplateMatchArray werden fur 
jeden Loop-Durchlauf die Variabl eToTempla teMa ten eingetragen. 

Nachdem das JobEnvironment gesetzt wurde,. werden vom PDF- 
Kernel die druckbaren Dateien anhand des virtuellen Druckers, 

25- der. in der: Konf iguration 1st, erstellt. Dafur hat der Kernel 
in einer besonders bevorzugten Ausfuhrungsform der Erf indung 
mehrere Ebenen. Auf der obersten Ebene (JobHandler) wird der. 
virtuelle Drucker ausgewahlt, der Print Job eingele'sen und das 
JobEnvironment initialisiert . Danach arbeltet der JobHandler; 

30 die PrepareDocwnentStep-Eintrage des virtuellen Druckers 

S«hrittweise ab. Auf dieser Ebene werden' die Eintrag© NewPDF. 
Loop, Workflow, Personalize, CreatereniplacePDF, . • 
PexsonalizeOnTemplate, Repeat und OpexiPDF erkannt, und in 
Abhangigkeit von dem Schlusselwo'rt wird eine Methode der 

35 nachsten Ebene aufgerufen. Auf der nachsten Ebene 
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(DocumefctHandler). werden die Anweimingen, die innerhalb der 
. : oben genannten.Eihtrage etehen, ausgewertet. Die. Eint rage, 
die in diesen Eintragen stehen, warden von einer weitereh 

• .Bbene (PDPDocument) .ausgewertet: PDFDocument benutzb 

5 PDFLayer, urn die Dokumente zu 6f fnen und zu erstellen; 

Zum Erstellen und/ Einlesen der .PDF-Dateieh wurde in einem 
besondera beyorzugten Ausf uhrungebeipiel der Erfindung eine , 

• .externa Bibliothek PCFLib eingebunden. . Diese BibliotheH .. 
io ermdglicht ein eihfach.es Erstellen , von PDF -Dokument en durch 

'■. ' Funktionsaufrufe. Vorhandene PDF-Seiten konnen.damit auch in " 
neue PDF-Dokumente einge'ffcgt werden. Die zugriffe auf diese 

• Bibliothek. lauf en ' vorzugaweise alle Ober einen 

• PDFAccessLayer. Dadurch ist der restliche C6de unabhangig von 
is der Bibliothek, und bei einer eventuellen Umscellung auf. eine 
andere Bibliothek muss nur das'; Layer angepasst warden. 

Das Layer ist auch verantwortlich ftir das i Setzen.vori 
DocumentBContent im JobEnvironment.' Bei jedem Anlegen einer 
.20 neuen PDF-Datei wird ein leerer PageContent er2eugt und dem 
. JobEnvironment mit dem Dateinamen mitgeteilt . Beim 

Personalisieren wird dem PDFLayer mitgeteilt, welche 
' ' Brief seite platziert wird. Das PDFLayer erzeugt ein 
entsprechendes PageContent und gibt dieaeB an JobEnvironment • • 
25 Bei jedem 6f'fnen einer vorhandenen Datel bolt sich das 

PDFLayer vom JobEnvironment die Seiteninhalte (PageContent) . 
. Wird von dieBem Dokument eine Seite in' ein neues Dokument 
kopiert, berechnet dfer PDFLayer die' Position der Seite auf 
der neuen Seite und generiert damit ein Pageeontent. 

Zur Konvertierung der . PDF-Dateien naqh Postscript hat es sich 
ale zwecktnaSig erwiesen, eine DLL pdf2ps_java. unter C zu 
verwenden: Diese DLL kann beiepielsweise die Programme Adobe 
Acrobat und Acrobat Reader ansprecheri. Die DLL 6ffnet die 
35 Programme und weist ©ie an, e*ine PDF-Datei nach Postscript zu 
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wandeln;. Die 'DLL Wirdl .von der Klasae Pd£2PE&ativelnber£acB . 
Baladen.' Die Klasae P.df2PBC6nve±rter benutzt 

Pd£2PeNSLi:iveInter£acB und .s'tellt sine Konyertierungsmethode 
• zur VerfCigung. 




\ 



AXG3 Nr 191927 von NVS:FAXG3.I0.0202/02414007121 an NVS:PRINTER.0101/LEXMARK2450 (Seite 59 von 72) 
atum 19.11.02 15:35 - Status: Server MRSDPAM02 (MRS 4,00) ubernahm Sendeauftrag • 
straff: 72 SeitefnVemofanaen 



19/11 2002 DI 16:55 FAX 2414007121 JUSTAKiwi -lavu 

kc DPA 5228 PDE. 



59 i . , ■ 

Patentansprttcbe: 

1. System zur automatisierten 'Erzeugung. von druckbaren 
• Dateien aus Daten einer Datenbank (30) , das ein 
, Drucksystem (10) beetebend aus, wenigstens. einer 

Druckverarbeitungskomponente (14) umfasst, wobei die 
. Druckverarbeitiingskomponente (14) - Mitt el zum 
Ausdrucken und/oder Weiterverarbeiten der druckbaren 
Dateien aufweist, gekennizeichnet durcb folgende 
" Merkmale: 



10 




15 




das DruckBystem (10) weist wenigstens ein 
Druckauftragerzeugungsndttel (15) auf, 

- . das Druckauftragerzeugungsmittel (15) ist CLber 
eine erste Schnittstelle (50) mit einem Server 
(20) verbindbar, 

der Server (20) ist uber eine. zweite Schnittstelle 
(40) ?nit einer Datenbank (30) verbindbar. 

das Druckauftragerzeugungsmittel (15) weist Mittel 
zum Anf ordern und Empf angen von Datsn aus der 
Datenbank (30) .auf;' und 

25 - das' Druckauftragerzeugungsmittel (15) weist Mittel 

zur Aufbereitung der Daten der Datenbank (30) fur- 
die. Anf orderungen der Druckverarbeitungskomponente 
(14) und Mittel zur Erzeugung von, druckbaren • 
Dateien auf . 



20 



20 



System nach Anspruch 1, da.<±ia:zrc!li 

gok^xari^eiclriil^-t., dass sich die Datenbank (3 0) 
auJSerhalb des Bereiches des Drucksystems (10) 
befindet. 
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' 3 . System nach einem oder beiden der Anspruche 1. und 2, 
cfLaciiaircti geO^exiraz ± clnnet , das a das 
DruckauftragerzeUgungsmittel ein Program auf 

wenigstens einem Computer dee Drucksystems' (10) ist. 

* 

s 4. system nach einem oder mehreren der vorangegangenen 

Ansprilche,, a&dL-iaarah. gekennzeictmet, dass es 
• sich bei der ersten Schnittstelle' (50) um eine SOAP • 
(Simple Object Access Protocol) -Schnittstelle handelt, 
wahrend der Server (20) ein SOAP -Server ist. 

10 5. System nach einem oder mehreren der vorangegangenen 

AnsprCtche,* caa.<axarcli gekennzeichnet, dass die 
SOAP-Schnittstelle als Dateniibertragungsprotokoll 
- htt'p/HTTPS einsetzt. . . 

; 6 . System nach einem oder mehreren der vorangegangenen 
is Anspruche, dadurch gekennze i olxn^ t , dass die 

Druckauftragerzeugtmgskomponente (i£) temporal- 
und/oder fest ubeir das Internet (60) mit dem Server 
(20) verbindbar ist. 

7 . System nach einem oder mehreren der vorangegangenen 
20 Anspruche , .<3.a.ciui3rola >c^xaxa z e x clone t , dass es 

sich bei der zweiten Schnittstelle (40) um ein 
PL/sQL(Frocedual Language /Structured Query Language) - 
Layer handelt . 



* 




8 • Verf ahren zur automatiaierten Erzeugung von druckbaren 
25 Dateien aus Daten einer Datenbank (30) , bei dem die . 

Dateien von einem Drucksystem (10) bestehend aus 
wenigstens einer Dxiickverarbeitungskomponente (14) und 
einem Druckauf tragerzeugungsmittel (IS) erzeugfc, 
ausgedruckt und/oder weiterverarbeitet werden, 
gelcenixz:©±C3tLix©t durch folgende Schritte: 



30 



Das DruckauftragerzeUgungsmittel (15) erzeugt 
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sine erste Nachricht (16) , die. einen Aufxuf einer 

«... » , i . 

* best immten- Metho.de mit Parametem' an einem Server 

(20) beinliaitet, 

5 m - Das Druckauftr&gerzeugungsmittel* (15) * stellt tiber 

1 eine erst.6 .Schnittstelle (40) eine Verbindurig zu 

dem Server (20) her, , 

-. das Druckauf tragerzeugungsmittel (1.5) {iberrnittelt 
iQ. • ••dem' Server (20) die erst^ Nachricht (16) uber die 

erste Schnittstelle (40) , 

der Server (20) verarbeitet die erste Nachricht 
I (16) , indera er die be^tinnnte Methode mit den ' 

is zugehoricfen- Pararaetern aufmft, 

• • ■ der Server (20) stellt ti!ber eine zweite • 
Schnittstelle (50) eine Verbindung zu der 
Datenbank (30) her, 

20 ' 

der Server (20) ruft tiber die zweite Schnittstelle 
'\ ' . (50)' Daten aus der Datenbank (3 0) ^b, 

- " der Server gibt das Ergebnis-, des Aufruf s der 
25 besfcitnmten Methode in Form ekner zweiten Nachricht 

(0.7) an das Druckauf tragerzeugungsmittel (15) 
zurtlck, und , 

, - das Druckauf tragerzeugungsTnittel (15) erzeugt aus 
30'* -dem Ergebnis des Aufruf s der besfeimmten Methode 

• . . wenigstens eine druckbare Datei. 

• • ■>"'•• 

9, verfahren nach Anspruch -8, ci^dL-Li^rcJlx 

gekenn z e i chne t ^ daa^ die Koirarninikation zwischen 
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dem DruckauftragerzeugungsTOittel (15) wd dam Server 
(20) uber eine SOAP-Sehhittstelle erfolgt. 

10. Verf aliren • nach Anepruch 9, dacatiroli 
gejcennzeichnet, dass die Kbmmunikation uber 

eine Apache SOAP-API erfolgt. 

t * ■ , , • '* ; 

11. ' Ver^ahren nach einem .oder mahreren der Anspriiche 8 bis, 
10, claa-U2rc2la gekennz e i chne t , dass die 
Kommunikation zwischen dem Server (20) und der 
Datenbanjc (3 0) uber ein PL/SQL (Procedual- 
Language/Structured Query. Language) -Layer erfolgt. 

12. Verfakren nach einem Oder mehreren der Anspruche .8 bis 
ll r ge3c^rirLZ^±clxp.et durch folgende Schrxtte: 

, das Dfuckauftragerzeugungsmittel (15) erzeugt eine 
erste Nachricht (16) , indem es eine Instanz einer 
Call-Klasse (18) einer Apache SOAP-API aufruft und 
Eigenschaften dieses Objektes setzt, ' ^ * 

das Druckauffcragerzeugungsmittel (15) ubermittelt 
2 o' dem Server (20) die erste Nachricht .(16), 

ff . . auf Seiten des Servers (20) nimmt ein Web-Server 
. (21) die erste ttachricht (IS) mit fietn Aufruf an 
und wertet diese aus, 



15 



25 



30 



der 'gesendeten URL wird ein rpcrouter-Servl.et der 
Apache SOAP -API zugeordnet, bei dem das Server- 
SOAP-Objekt bekahnt iBt, 

der Aufruf wird dieeem Servlet ubergeben, 

das rpcrouter- Servlet analysiert die erste SOAP- 
Nachricht (16) , bestimmt die auf zurufende Klasse 



AXG3 Nn 191927 von NVS:FAXG3.I0.0202/02414007121 an NVS:PRINTER.0101/LEXMAFy<2450 (Seite 63 von 72) 
atum 19.11.02 15:35 - Status: Server MRSDPAM02 (MRS 4.00) ubernahm Sendeauftrag 
etreff: 72 Seite(n)empfangen 



19/11 2002 DI. 16:57 FAX 2414007121 rAis ju»i;akwi/i iuuj. 

AC DPA 5228 PDE • 



S3 

und instanziiert diese/ 



u Die gewunschte Methode wird mi t den ubergebenen 
Parametern aufgerufen. 

Der Ruckgabewert wird in eine zweite SOAP-: 
Nachrieht (17) umgewandelt und dlese wird als 
' Antwort per HTTP zuruckgelief ert , 

xo ' die 'ciientseitige •* Instanz der Call-Klasse (18) 

analysiert die zweite Nachricht (17) und gibt das 
entstandene Ergebnie. zuruck an das. 
Druckauftragerzeugungsmittel (15) v 

is 13 . Verf ahren nach einera oder mehreren der Anepruche 8 bie 

12, dadLiaaral* gekenn s e i chne t , dass das 
Drlickauftragserzeugungsmittel (15) bei einem Start 
.uberpruft, ob auf dem Server .■ (20). Update© vorliegen . 
und eeine Konf iguration im Falle eines vorhandenen 

20 .updates automatisch aktualisiert . 

14. Verf ahren nach Ariapmch 13, da^-uarclx 

g^lc©xixise±olinoti , da^s bei der Aktualisierung 
eine neue Verarbeitungsdatei tibermittelt wird. 
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Zusammenf assung: 4 , 

Die Erf indung betrif f t- ein System zur automatisierten 
Erzeugung von druckbaren Dateien aus Daten einer Datenbank 
(30) , das ein Drucksystem (10) bestehend aus wenigstens einer 
5 DrucJcverarbeitT^gekomponehte (14) umfasst, wobei die 

Druckverarbeitungakomponente Mittel zum Ausdrucken und/oder 
Weiterverarbeiten der Dateien aufweist. 

* » " ' 

Das earf indung sgemSSe System zeichnet sich dadurch aus, dass 
das Drucksystem ein Druckauf t^agerzeugimgamittel (15) 
lo aufweist, das uber eine Schnittsfcelle (40) in Verbindung mit 
.einem Server (20) etehty der fiber eine weitere Schnittptelle 
(50) mit der Datenbank" (30) verbihdbar ist. 



• Die Erf indung betrif ft ferner ein Verfahr'en zur 

automatisierten Erzeugung von • druckbaren Dateien aus Daten 
is einer Datenbank (3 0) , bei dem die Dateien von einem 
Drucksystem (10). besteherid aus wenigstens einer 
Druckverarbeitungskomponente (14) und einem 
Druckauftragerzeugungsmittel (15) erzeugt, ausgedruckt 
und/oder weiterverarbeitet werden. 
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(Fig. 1) " . / 
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Bezugszeichenliste: - 

10 Druckaystdm 

11 Drucker 
,12 ' Sortieranlage 

5. 13 Kuvertieranlage 

14 Druclcverarbeitungskotitpoiiente 

15 Druckauf tragerzeugiingsmittel 
i.6 Brste Nachricht 

17 • Zweite Nachricht 
10 18 Call-Klasse' 

20 Server 

21 , Web -Server 

22 Proxy-Server 
. 30 Datenbank 

15 40 Erate Schnittetelle 

50 * Zweite- Schnittstelle 
60 Internet 
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SOAP-Server 



MelhcdenName 



Fig; 2 
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' * ' Fig. 3 
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. Fig- 4 
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